• 前端基础入门之JS BOM简介


    BOM

    1、BOM

    BOM:浏览器对象模型

    BOM 可以使我们通过 JS 来操作浏览器

    在 BOM 中为我们提供了一组对象,用来完成对浏览器的操作 BOM 对象

    Window

    代表的是整个 浏览器的窗口,同时 window 也是网页中的全局对象

    Navigator

    代表的当前 浏览器的信息,通过该对象可以来识别不同的浏览器

    Location

    代表当前 浏览器的地址栏信息,通过 Location 可以获取地址栏信息,或者操作浏览器跳转页面

    History

    代表 浏览器的历史记录,可以通过该对象来操作浏览器的历史记录由于隐私原因

    该对象不能获取到具体的历史记录,只能操作 浏览器向前或向后翻页,而且该操作只在当次访问时有效

    Screen

    代表用户的 屏幕的信息,通过该对象可以获取到用户的显示器的相关的信息

    Screen

    这些 BOM 对象在浏览器中都是作为 window 对象的属性保存的,可以通过 window 对象来使用,也可以直接使用

    image-20210811201317053

    console.log(window); // [object Window]
    console.log(navigator); // [object Navigator]
    console.log(location); // [object Object]
    console.log(history); // [object History]
    console.log(screen); // [object Screen]
    
    • 1
    • 2
    • 3
    • 4
    • 5

    2、Navigator

    Navigator

    由于历史原因,Navigator对象中的大部分属性都已经不能帮助我们识别浏览器了

    console.log(navigator.appName); //Chrome/Firefox/Edge/IE11:Netscape;IE10及以下:Microsoft Internet Explorer
    
    • 1

    那既然如此,我们要怎么判断不同的浏览器呢?

    一般我们只会使用userAgent来判断浏览器的信息,userAgent是一个字符串

    这个字符串中包含有用来描述浏览器信息的内容,不同的浏览器会有不同的userAgent

    console.log(navigator.userAgent);
    // Chrome: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.85 Safari/537.36
    // Firefox:Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:90.0) Gecko/20100101 Firefox/90.0
    // Edge:   Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.131 Safari/537.36 Edg/92.0.902.67
    // IE11:   Mozilla/5.0 (Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729; rv:11.0) like Gecko
    // IE10:   Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729)
    // IE9:    Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729)
    // IE8:    Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729)
    // IE7/IE5:Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 10.0; WOW64; Trident/7.0; .NET4.0C; .NET4.0E; .NET CLR 2.0.50727; .NET CLR 3.0.30729; .NET CLR 3.5.30729)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    我们可以根据userAgent中特有的标识符来判断是哪个浏览器

    var ua = navigator.userAgent;
    if (/edg/i.test(ua)) {
        alert("Edge浏览器");
    } else if (/firefox/i.test(ua)) {
        alert("火狐浏览器");
    } else if (/chrome/i.test(ua)) {
        alert("谷歌浏览器");
    } else if (/msie/i.test(ua)) {
        alert("IE浏览器");
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在 IE11 中已经将微软和 IE 相关的标识都已经去除了,所以我们基本已经不能通过userAgent来识别一个浏览器是否是 IE 了

    那么,我们要怎么判断统一是否是 IE 呢?

    还是要 找特殊 ,我们根据之前知识,知道currentStyleattchEvent是 IE 所特有的

    除此之外,还有个ActiveXObject也是 IE 中所特有的,我们可以根据这个来做判断

    // 利用`ActiveXObject`是 IE 中特有的属性,以及通过`window.属性 == undefined`特点来判断是否是 IE
    if(window.ActiveXObject){
        alert("IE浏览器");
    } else{
        alert("非IE浏览器");
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    我们直接在 IE 中进行测试

    image-20210811204751369

    不是说ActiveXObject也是 IE 中所特有的吗?怎么不行呢?

    我们在 IE11 中打印下window.ActiveXObject是否等于true

    // 利用两次使用`!!`将任意值转换成bool值
    console.log(!!window.ActiveXObject); // false
    
    • 1
    • 2

    What? 这?

    别急,我们换种方式,利用in来判断 window 中是否包含某个属性

    console.log("ActiveXObject" in window); // true
    
    • 1

    我们来完善下对 IE11 的判断逻辑

    var ua = navigator.userAgent;
    if (/edg/i.test(ua)) {
        alert("Edge浏览器");
    } else if (/firefox/i.test(ua)) {
        alert("火狐浏览器");
    } else if (/chrome/i.test(ua)) {
        alert("谷歌浏览器");
    } else if (/msie/i.test(ua)) {
        alert("IE浏览器");
    } else if ("ActiveXObject" in window) {
        alert("IE11浏览器");
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    3、History

    image-20210811205755795

    length

    length属性,可以获取到当次访问的链接数量

    alert(history.length);
    // 访问History页面:1
    // 访问Test02页面并跳转至History页面:2
    // 访问Test01页面并跳转至History页面:3
    
    • 1
    • 2
    • 3
    • 4

    back()

    可以用来回退到上一个页面,作用和浏览器的回退按钮一样

    history.back();
    
    • 1

    history-back

    forward()

    可以跳转下一个页面,作用和浏览器的前进按钮一样

    history.forward();
    
    • 1

    forward

    go()

    可以用来跳转到指定的页面,它需要一个整数作为参数

    • 1:表示向前跳转一个页面,相当于forward()
    • 2:表示向前跳转两个页面
    • -1:表示向后跳转一个页面,相当于back()
    • -2:表示向后跳转两个页面
    history.go(2);
    
    • 1

    history-go

    history.go(-2);
    
    • 1

    history-go

    4、Location

    如果直接打印location,则可以获取到地址栏的信息(当前页面的完整路径)

    alert(location); // http://127.0.0.1:8848/Demo/17-04-Location.html
    
    • 1

    如果直接将location属性修改为一个完整的路径,或相对路径则我们页面会自动跳转到该路径,并且会生成相应的历史记录

    location = "http://www.baidu.com";
    
    • 1

    location

    location = "17-03-History.html";
    
    • 1

    location2

    其他属性方法

    image-20210811213202215

    assign()

    用来跳转到其他的页面,作用和直接修改location一样

    会生成历史记录, 能使用回退按钮回退

    location.assign("http://www.baidu.com");
    
    • 1

    location-assign

    replace()

    可以使用一个新的页面替换当前页面,调用完毕也会跳转页面

    不会生成历史记录,不能使用回退按钮回退

    location.replace("17-03-History.html");
    
    • 1

    replace

    reload()

    用于重新加载当前页面,作用和刷新按钮(F5)一样

    location.reload();
    
    • 1

    location-reload

    如果在方法中传递一个true,作为参数,则会强制清空缓存刷新页面(Ctrl + F5)

    location.reload(true);
    
    • 1

    location-reload(true)

  • 相关阅读:
    只依赖OPENCV的工作服安全帽检测YOLOV8S
    详细解释HiveSQL执行计划
    天玑900和麒麟810性能哪个好?
    P10.2机器学习笔记--李宏毅(self-attention机制)
    Redis能保证数据不丢失吗?
    基于openEuler虚拟机远端执行mugen测试脚本
    “池化技术” - 深度剖释底层内存管理细节,明晰“池化技术”内存管理技术
    Mysql相关操作命令合集
    图文看懂JavaScritpt引擎V8与JS执行过程
    大气污染扩散模型Calpuff实践
  • 原文地址:https://blog.csdn.net/agonie201218/article/details/125418833