ECMAScript 是 JavaScript 的核心,但如果要在 Web 中使用 JavaScript,那么 BOM(浏览器对象模
型)则无疑才是真正的核心。BOM 提供了很多对象,用于访问浏览器的功能,这些功能与任
何网页内容无关。多年来,缺少事实上的规范导致 BOM 既有意思又有问题,因为浏览器提供商会按照各
自的想法随意去扩展它。于是,浏览器之间共有的对象就成为了事实上的标准。这些对象在浏览器中得以
存在,很大程度上是由于它们提供了与浏览器的互操作性。W3C 为了把浏览器中 JavaScript 最基本的部分
标准化,已经将 BOM 的主要方面纳入了 HTML5 的规范中。

1.window对象

  BOM 的核心对象是 window,它表示浏览器的一个实例。在浏览器中,window 对象有双重角色,
它既是通过 JavaScript 访问浏览器窗口的一个接口,又是 ECMAScript 规定的 Global 对象。这意味着
在网页中定义的任何一个对象、变量和函数,都以 window 作为其 Global 对象,因此有权访问
parseInt()等方法。

1.1 全局作用域

有在全局作用域中声明的变量、函数都会变成 window 对象的属性和方法。但定义全局变量与在 window 对象上直接定义属性还是有一点差别:

  1. 全局变量不能通过 delete 操作符删除,而直接在 window 对象上的定义的属性可以。
    var age = 29;
    window.color = "red";
    //在 IE < 9 时抛出错误,在其他所有浏览器中都返回 false
    delete window.age;
    //在 IE < 9 时抛出错误,在其他所有浏览器中都返回 true
    delete window.color; //returns true
    alert(window.age); //29
    alert(window.color); //undefined
  2. 直接访问未定义的变量会抛出错误,但是访问未定义的window属性则不会,会返回undefined。可以知道某个可能未声明的变量是否存在。

    1.2 导航和打开窗口

函数:window.open(URL,窗口目标,特性字符串,是否打开新页面标志);
四个参数中,一般只需要传URL,最后一个参数传_self时新窗口覆盖当前窗口,默认为打开新窗口。
特性表:

表中所列的部分或全部设置选项,都可以通过逗号分隔的名值对列表来指定。其中,名值对以等号
表示(注意,整个特性字符串中不允许出现空格),如下面的例子所示。

window.open("http://www.baidu.com","wroxWindow",
"height=400,width=400,top=10,left=10,resizable=yes");

返回值:新打开窗口的window对象
opener属性:新打开的窗口都有一个opener属性,保存着打开它的原始窗口的window对象。但原始窗口中并没有这样的指针指向弹出窗口。可指定opener为null;
opener.close():可以关闭本窗口中通过js打开的窗口;
不同浏览器使用close()方法的策略不同:

  1. ff : 无法关闭
  2. chrome : 直接关闭
  3. ie : 询问用户
<button>open</button>
<button>close</button>

<script>
  var oBtn = document.getElementsByTagName('button')[0];
  var oBtn1 = document.getElementsByTagName('button')[1];
  var wroxWin; 
  oBtn.onclick = function(){
    wroxWin = window.open("http://www.baidu.com/","wroxWindow",
        "height=400,width=400,top=10,left=10,resizable=yes");
    // wroxWin.opener = null;
    console.log(wroxWin);
  };
  oBtn1.onclick = function(){
    wroxWin.close();
  }
</script>

1.3 窗口尺寸

1.3.1可视区尺寸

document.documentElement.clientWidth
document.documentElement.clientHeight

1.3.2 滚动条滚动距离

var scrollTop = document.documentElement.scrollTop || document.body.scrollTop(Left)

1.3.3 内容高度(宽度)

Element.scrollHeight (Width)这个只读属性是一个元素内容高度的度量,包括由于溢出导致的视图中不可见内容。

1.3.4 offsetHeight /Width

HTMLElement.offsetHeight 是一个只读属性,它返回该元素的像素高度,高度包含该元素的垂直内边距和边框,且是一个整数。
通常,元素的offsetHeight是一种元素CSS高度的衡量标准,包括元素的边框、内边距和元素的水平滚动条(如果存在且渲染的话),不包含:before或:after等伪类元素的高度。
对于文档的body对象,它包括代替元素的CSS高度线性总含量高。浮动元素的向下延伸内容高度是被忽略的。
这个属性值会被四舍五入为整数值,如果你需要一个浮点数值,请用 element.getBoundingClientRect().

2.location对象

最有用的BOM对象之一,既是window的属性,又是document的属性。location存储着当前文档的信息,并且将 URL 解析为独立的片段,可以通过location对象的属性访问,下面是所有的location属性:

2.1 获取包含查询字符串的对象

function getQueryStringArgs(){ 
 //取得查询字符串并去掉开头的问号
  var qs = (location.search.length > 0 ? location.search.substring(1) : ""), 
  
  //保存数据的对象
  args = {}, 
  
  //取得每一项
  items = qs.length ? qs.split("&") : [], 
  item = null, 
  name = null, 
  value = null, 
  //在 for 循环中使用
  i = 0, 
  len = items.length; 
  //逐个将每一项添加到 args 对象中
  for (i=0; i < len; i++){ 
      item = items[i].split("="); 
      name = decodeURIComponent(item[0]); 
      value = decodeURIComponent(item[1]); 
      if (name.length) { 
      args[name] = value; 
      } 
 } 
 
 return args; 
}

2.2 改变浏览器位置

  1. location.assign( URL )方法:立即打开新 URL 并在浏览器的历史记录中生成一条记录。修改window.location或者location.href也会调用assign方法,效果相同。修改表中location的属性也可改变浏览器位置。
  2. location.replace( URL ),载入新页面且不会生成历史记录,无法回退。
  3. location.reload( true(可选) ),重新载入页面,如果调用 reload()
    时不传递任何参数,页面就会以最有效的方式重新加载。也就是说,如果页面自上次请求以来并没有改变过,页面就会从浏览器缓存中重新加载。如果要强制从服务器重新加载,需加参数true。位于 reload()调用之后的代码可能会也可能不会执行,这要取决于网络延迟或系统资源等因素。为此,最好将 reload()放在代码的最后一行。

本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!

DOM 上一篇
vue插值表达式 下一篇