BOM

作者: 好奇男孩 | 来源:发表于2018-04-03 11:01 被阅读67次

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

    用于描述这种对象与对象之间层次关系的模型,浏览器对象模型提供了独立于内容的、可以与浏览器窗口进行互动的对象结构。BOM由多个对象组成,其中代表浏览器窗口的Window对象是BOM的顶层对象,其他对象都是该对象的子对象。

    window

    BOM 的核心是window对象,它表示浏览器的一个实例。在浏览器中,即是javascript访问浏览器窗口的一个接口,又是ECMAScript规定的Global对象,这就意味着在网页中定义的任意变量、函数、对象都是以window作为Global对象。
    所有在全局作用域中声明的变量、函数、对象都会作为window的属性和方法

    范例

    var age = 24;
    
    function printName(){
        console.log(age);
    }
    
    console.log(window.age);
    window.printName();
    24
    24
    

    window属性

    window.frames(已被废弃)

    window.frames返回一个类似数组的对象,成员为页面内的所有框架,包括frame元素和iframe元素。需要注意的是,window.frames的每个成员对应的是框架内的窗口(即框架的window对象),获取每个框架的DOM树,需要使用window.frames[0].document。

    var iframe = window.getElementsByTagName("iframe")[0];
    var iframe_title = iframe.contentWindow.title;
    

    上面代码用于获取框架页面的标题。

    iframe元素遵守同源政策,只有当父页面与框架页面来自同一个域名,两者之间才可以用脚本通信,否则只有使用window.postMessage方法。

    在iframe框架内部,使用window.parent指向父页面

    navigator

    Window对象的navigator属性,指向一个包含浏览器相关信息的对象。
    navigator.userAgent属性返回浏览器的User-Agent字符串,用来标示浏览器的种类。下面是Chrome浏览器的User-Agent。

    navigator.userAgent // "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_3) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36"
    

    通过userAgent属性识别浏览器,不是一个好办法。因为必须考虑所有的情况(不同的浏览器,不同的版本),非常麻烦,而且无法保证未来的适用性,更何况各种上网设备层出不穷,难以穷尽。所以,现在一般不再识别浏览器了,而是使用“功能识别”方法,即逐一测试当前浏览器是否支持要用到的JavaScript功能。

    范例:判断用户的浏览器类型

        function isAndroid(){
            return /Android/.test(navigator.userAgent);
        }
        function isIphone(){
            return /iPhone/.test(navigator.userAgent);
        }
        function isIpad(){
            return /iPad/.test(navigator.userAgent);
        }
        function isIOS(){
            return /(iPad)|(iPhone)/.test(navigator.userAgent);
        }
    

    screen

    screen对象包含了显示设备的信息

    // 显示设备的高度,单位为像素
    screen.height
    // 900
    
    // 显示设备的宽度,单位为像素
    screen.width
    // 1600
    

    一般使用以上两个属性,了解设备的分辨率。上面代码显示,我的PC设备的分辨率是900x1600。除非调整显示器的分辨率,否则这两个值可以看作常量,不会发生变化。显示器的分辨率与浏览器设置无关,缩放网页并不会改变分辨率。

    window.getComputedStyle

    getComputedStyle是一个可以获取当前元素所有最终使用的CSS属性值。返回的是一个CSS样式声明对象([object CSSStyleDeclaration])
    一看这个函数的名字我们就知道问题解决了

      var style = window.getComputedStyle("元素", "伪类");
    //第二个参数没有伪类则不设置
    var div = document.getElementById('test');
    console.log(getComputedStyle(div).width);
    //这个是低版本IE的实现方案,我们可以写个兼容的方式
    element.currentStyle ?
        element.currentStyle : window.getComputedStyle(element, null)
    

    URL的编码/解码方法

    • URL只能使用英文字母、阿拉伯数字和某些标点符号,不能使用其他文字和符号;如果URL中有汉字,就必须编码后使用;
    • 为什么不能有汉字呢?中文字库内存太大了;通常如果一样东西需要编码,说明这样东西并不适合传输。原因多种多样,如Size过大,包含隐私数据,对于Url来说,之所以要进行编码,是因为Url中有些字符会引起歧义。
    • Url编码的原则:就是使用安全的字符(没有特殊用途或者特殊意义的可打印字符)去表示那些不安全的字符。

    JavaScript提供四个URL的编码/解码方法。

    1.decodeURI()
    2.decodeURIComponent()
    3.encodeURI()
    4.encodeURIComponent()

    encodeURI方法不会对下列字符编

    ASCII字母
    数字
    ~!@#$&*()=:/,;?+'

    encodeURIComponent方法不会对下列字符编码

    ASCII字母
    数字
    ~!*()'

    所以encodeURIComponent比encodeURI编码的范围更大。

    encodeURIComponent会把 http:// 编码成 http%3A%2F%2F 而encodeURI却不会。

    如果你需要编码整个URL,然后需要使用这个URL,那么用encodeURI。

    encodeURI("http://blog.jirengu.com/?cat=11&a=小灰")
    "http://blog.jirengu.com/?cat=11&a=%E5%B0%8F%E7%81%B0"
    

    其中,汉字被编码

    但是如果你用了encodeURIComponent,那么结果变为

    encodeURIComponent("http://blog.jirengu.com/?cat=11&a=小灰")
    "http%3A%2F%2Fblog.jirengu.com%2F%3Fcat%3D11%26a%3D%E5%B0%8F%E7%81%B0"
    

    alert(),prompt(),confirm() (不常用)

    alert()、prompt()、confirm()都是浏览器用来与用户互动的方法。它们会弹出不同的对话框,要求用户做出回应。
    需要注意的是,alert()、prompt()、confirm()这三个方法弹出的对话框,都是浏览器统一规定的式样,是无法定制的。

    alert方法弹出的对话框,只有一个“确定”按钮,往往用来通知用户某些信息。

    alert("Hello World");
    

    用户只有点击“确定”按钮,对话框才会消失。在对话框弹出期间,浏览器窗口处于冻结状态,如果不点“确定”按钮,用户什么也干不了。

    prompt方法弹出的对话框,在提示文字的下方,还有一个输入框,要求用户输入信息,并有“确定”和“取消”两个按钮。它往往用来获取用户输入的数据。

    // 格式
    var result = prompt(text[, default]);
    
    // 实例
    var result = prompt('您的年龄?', 18)
    

    上面代码会跳出一个对话框,文字提示为“您的年龄?”,要求用户在对话框中输入自己的年龄(默认显示18)。
    prompt方法的返回值是一个字符串(有可能为空)或者null,具体分成三种情况

    • 用户输入信息,并点击“确定”,则用户输入的信息就是返回值。
    • 用户没有输入信息,直接点击“确定”,则输入框的默认值就是返回值。
    • 用户点击了“取消”(或者按了Escape按钮),则返回值是null。
      prompt方法的第二个参数是可选的,但是如果不提供的话,IE浏览器会在输入框中显示undefined。因此,最好总是提供第二个参数,作为输入框的默认值。

    confirm方法弹出的对话框,除了提示信息之外,只有“确定”和“取消”两个按钮,往往用来征询用户的意见。

    // 格式
    var result = confirm(message);
    
    // 实例
    var result = confirm("你最近好吗?");
    

    上面代码弹出一个对话框,上面只有一行文字“你最近好吗?”,用户选择点击“确定”或“取消”。
    confirm方法返回一个布尔值,如果用户点击“确定”,则返回true;如果用户点击“取消”,则返回false。

    window.onload 和 document.onDOMContentLoaded 的区别?

    • 1.onload要等到所有页面元素加载完成才会触发, 包括页面上image、flash、iframe等内容都加载完毕才会执行。

    • 2 document.onDOMContentLoaded在页面中触发[DOMContentLoaded]事件时触发。此时,文档被加载和解析,当所有DOM解析完以后会触发这个事件,但链接的资源(例如图像,样式表和子帧)可能尚未被加载。

      1. window.onload不同同时编写多个,如果有多个window.onload方法,只会执行一个
        document.onDOMContentLoaded可以同时编写多个,并且可以得到执行
    • 4.onload 是window 的事件 可以直接只用window.onload=function(){}使用
      DomContentLoaded是document 上的事件续注册后使用document.addEventListener('DomContentLoaded',function(){});

    相关文章

      网友评论

        本文标题:BOM

        本文链接:https://www.haomeiwen.com/subject/uxhqhftx.html