11_BOM相关对象

导读:本篇文章讲解 11_BOM相关对象,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

1.认识BOM

BOM:浏览器对象模型(Browser Object Model)

  • 简称 BOM,由浏览器提供的用于处理文档(document)之外的所有内容的其他对象;
  • 比如navigator、location、history等对象;

JavaScript有一个非常重要的运行环境就是浏览器

  • 而且浏览器本身又作为一个应用程序需要对其本身进行操作;
  • 所以通常浏览器会有对应的对象模型(BOM,Browser Object Model);
  • 我们可以将BOM看成是连接JavaScript脚本与浏览器窗口的桥梁;

BOM主要包括一下的对象模型:

  • window:包括全局属性、方法,控制浏览器窗口相关的属性、方法;
  • location:浏览器连接到的对象的位置(URL);
  • history:操作浏览器的历史;
  • navigator:用户代理(浏览器)的状态和标识(很少用到);
  • screen:屏幕窗口信息(很少用到);

2.全局对象window

2.1 认识window对象

window对象在浏览器中可以从两个视角来看待:

  1. 视角一:全局对象。
    • 我们知道ECMAScript其实是有一个全局对象的,这个全局对象在Node中是global;
    • 在浏览器中就是window对象
  2. 视角二:浏览器窗口对象。
    • 作为浏览器窗口时,提供了对浏览器操作的相关的API;

当然,这两个视角存在大量重叠的地方,所以不需要刻意去区分它们:

  • 事实上对于浏览器和Node中全局对象名称不一样的情况,目前已经指定了对应的标准称之为globalThis,并且大多数现代
    浏览器都支持它;
  • 放在window对象上的所有属性都可以被访问;
  • 使用var定义的变量会被添加到window对象中;
  • window默认给我们提供了全局的函数和类:setTimeout、Math、Date、Object等;

2.2 window对象的作用

事实上window对象上肩负的重担是非常大的:

  • 第一:包含大量的属性,localStorage、console、location、history、screenX、scrollX等等(大概60+个属性);
  • 第二:包含大量的方法,alert、close、scrollTo、open等等(大概40+个方法);
  • 第三:包含大量的事件,focus、blur、load、hashchange等等(大概30+个事件);
  • 第四:包含从EventTarget继承过来的方法,addEventListener、removeEventListener、dispatchEvent方法;

那么这些大量的属性、方法、事件在哪里查看呢?

  • MDN文档:https://developer.mozilla.org/zh-CN/docs/Web/API/Window

查看MDN文档时,我们会发现有很多不同的符号,这里我解释一下是什么意思:

  • 删除符号:表示这个API已经废弃,不推荐继续使用了;
  • 感叹符号:表示这个API不属于W3C规范,某些浏览器有实现(所以兼容性的问题);
  • 实验符号:该API是实验性特性,以后可能会修改,并且存在兼容性问题;

2.3 window常见属性

我们来看一下常见的windo属性:

//浏览器高度和宽度
console.log(window.outerHeight);
console.log(window.outerWidth);

//浏览器相对于电脑屏幕的距离
console.log(window.screenX);
console.log(window.screenY);

2.4 window常见方法

我们来看一下常见的window方法:

// 1.open方法 打开一个新的窗口
<button class="open">百度一下</button>
<script>
  var openBtnEl = document.querySelector(".open");
  openBtnEl.onclick = function () {
    window.open("http://www.baidu.com");
  };
</script>
// 2.close方法 关闭窗口(只能关闭open方法打开的窗口)
<button class="close">关闭</button>
<script>
  var openBtnEl = document.querySelector(".close");
  openBtnEl.onclick = function () {
    window.close;
  };
</script>

2.5 window常见事件

我们来看一下常见的window事件:

//获取失去焦点
window.onfocus = function () {
  console.log("窗口获取到焦点");
};
window.onblur = function () {
  console.log("窗口失去了焦点");
};

// hash发生改变
window.onhashchange = function () {
  console.log("hash发生了改变");
};

3.location对象

location对象用于表示window上当前链接到的URL信息。

3.1 location常见属性

  • href: 当前window对应的超链接URL, 整个URL;

  • console.log(location.href);
    
  • protocol: 当前的协议;

  • console.log(location.pathname);
    
  • host: 主机地址;

  • console.log(location.host);
    
  • hostname: 主机地址(不带端口);

  • console.log(location.hostname);
    
  • port: 端口;

  • console.log(location.port)
    
  • pathname: 路径;

  • console.log(location.pathname)
    
  • search: 查询字符串;

  • console.log(location.search)
    
  • hash: 哈希值;

  • console.log(location.hash)
    
  • username:URL中的username(很多浏览器已经禁用);

  • password:URL中的password(很多浏览器已经禁用);

3.2 location常见方法

我们会发现location其实是URL的一个抽象实现:
在这里插入图片描述

location有如下常用的方法:

  • assign:赋值一个新的URL,并且跳转到该URL中(**有前进后退的按钮 **);

  • <button>打开新的网页</button>
    <script>
      var btnEl = document.querySelector("button");
      btnEl.onclick = function () {
        location.assign("http://www.baidu.com");
      };
    </script>
    
  • replace:打开一个新的URL,并且跳转到该URL中(不同的是不会在浏览记录中留下之前的记录, 不可前进后退);

  • <button>替换新的网页</button>
    <script>
      var btnEl = document.querySelector("button");
      btnEl.onclick = function () {
        location.replace("http://www.baidu.com");
      };
    </script>
    
  • reload:重新加载页面,可以传入一个Boolean类型;

  • <button>重新加载网页</button>
    <script>
      var btnEl = document.querySelector("button");
      btnEl.onclick = function () {
        location.reload("http://www.baidu.com");
      };
    </script>
    

3.3 URLSearchParams

URLSearchParams 定义了一些实用的方法来处理 URL 的查询字符串。

  • 可以将一个字符串转化成URLSearchParams类型;
  • 也可以将一个URLSearchParams类型转成字符串;

URLSearchParams常见的方法有如下:

  • get:获取搜索参数的值;
  • set:设置一个搜索参数和值;
  • append:追加一个搜索参数和值;
  • has:判断是否有某个搜索参数;
  • https://developer.mozilla.org/zh-CN/docs/Web/API/URLSearchParams
var urlSearch = "?name=coder&age=18&height=1.98";
var searchParams = new URLSearchParams(urlSearch);
// 获取搜索参数的的值
console.log(searchParams.get("name"));
console.log(searchParams.get("age"));
console.log(searchParams.get("height"));

// 判断是否有某个搜索参数
console.log(searchParams.has("age"));

// 追加一个搜索参数和值
searchParams.append("sex", "男");
console.log(searchParams.get("sex"));

中文会使用encodeURIComponent和decodeURIComponent进行编码和解码

4.history对象

history对象允许我们访问浏览器曾经的会话历史记录。

4.1 history常见属性

有两个属性:

  • length:会话中的记录条数;
  • state:当前保留的状态值;
console.log(history.length)
console.log(history.state)

4.2 history常见方法

有五个方法:

  • back():返回上一页,等价于history.go(-1);
  • forward():前进下一页,等价于history.go(1);
  • go():加载历史中的某一页;
  • pushState():打开一个指定的地址;
  • replaceState():打开一个新的地址,并且使用replace(不能返回历史);
<button class="back">按钮</button>
<script>
	var backBtnEl = document.querySelector(".back")
		backBtnEl.onclick = function() {
    // 后退
		history.back()
		// 前进
		history.forward()
		// 类似于上面的两个方法, 只是可以传入层级例如传入-2后退两步
		history.go(-2)
	}  
</script>

history和hash目前是vue、react等框架实现路由的底层原理,具体的实现方式我会在后续讲解。

5.navigator对象(很少使用)

navigator 对象表示用户代理的状态和标识等信息。

在这里插入图片描述

6.screen对象(很少使用)

screen主要记录的是浏览器窗口外面的客户端显示器的信息:

  • 比如屏幕的逻辑像素 screen.width、screen.height;

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/120149.html

(0)
seven_的头像seven_bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!