Skip to content

about

浏览器对象模型(BOM,Browser Object Model),专门用来完成对浏览器的各种操作。

BOM这部分,内容不多,主要包括:

  • Window:代表的是浏览器的窗口。
  • History:代表的是浏览器的历史记录。
  • Location:代表的是浏览器的地址。
  • Navigator:代表浏览器的信息。
  • Screen:代表的是设备屏幕信息。

注意,BOM对象都是window对象的属性,所以可以通过window访问,也可以直接访问:

html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    // 直接访问
    console.log(navigator);
    // 通过window对象访问
    console.log(window.navigator);
</script>
</body>
</html>

以上两种访问方式是等价的。

Window

window对象我们已经不陌生了,它代表的是浏览器的窗口对象,一些属性和方法我们也使用过,所以这里不在多表,可以参考:

History

由于隐私的原因,history无法访问具体的历史记录,只能用来控制浏览器向前向后翻页。

方法描述
history.length当前窗口中,历史记录的数量
history.forward()向前跳转
history.back()向后跳转
history.go(number)跳转到历史记录中的第几个网址

注意,history是个只读属性,也就意味着,我们无法清空历史记录,从而达到禁止浏览器回退的目的,如果有此需求,最快捷的可用方式是使用window.location.replace()方法,提供指定的 URL 来替换当前的会话历史(session history)。 参考:https://developer.mozilla.org/zh-CN/docs/Web/API/Window/history

Location

location用来处理跟地址栏相关的信息。

html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<button id="btn">点我</button>
<script>
    let bd = 'https://www.baidu.com';
    let btn = document.getElementById('btn');
    btn.addEventListener('click', function () {
        // 获取完整的地址栏信息
        // console.log(location);
        // console.log(location.hostname); // localhost
        // console.log(location.host); // localhost:63342
        // console.log(location.protocol); // http:
        // console.log(location.port); // 63342
        // console.log(location.origin); // http://localhost:63342
        // console.log(location.href); // http://localhost:63342/web/05.html?_ijt=usak6gkrt769ri6j80u28k7aij
        
        // 跳转到指定地址,会保留历史记录
        // location = bd;

        // 跳转到指定地址,会保留历史记录
        // location.assign(bd);

        // 跳转到指定地址,不会保留历史记录,即无法通过回退按钮回退
        // location.replace(bd);

        // 刷新当前页
        // location.reload();
    });
</script>
</body>
</html>

获取地址栏中的中文字符

有些时候,我们需要获取地址栏中的中文,比如获取name=张开,而这个张开通常会进行转义b.html?name=%E5%BC%A0%E5%BC%80,那么如果需要在页面中使用这个参数值,就需要进行decode转义回来。 这里主要用到了decodeURIComponent方法,具体用法参考:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/decodeURIComponent 也来个示例:

html
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
<div>
    <input type="text" id="msg">
    <button type="button" id="btn">获取url上的中文</button>
    <button type="button" id="add">添加参数</button>
</div>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.js"></script>
<script>
    // 懒得手动填地址栏输入参数值,就点击button按钮搞了
    var path = window.location.href;
    $("#add").click(function () {
        window.location.href = path + "?name=张开";
    })
    
    
    // 获取参数值
    function GetQueryString(name) {
        var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");
        var r = window.location.search.substr(1).match(reg);
        if (r != null) return (r[2]);
        return null;
    }
    // 获取地址栏上指定参数的值,并展示到input框中
    $("#btn").click(function () {
        console.log('原始url: ', window.location.href)
        var sname = GetQueryString("name");
        if (sname != null) {
            var sname_ = decodeURIComponent(sname);
            alert(sname_);
        }
        var value = GetQueryString("name");
        $("#msg").val(decodeURIComponent(value));
    })
</script>
</body>
</html>

参考:

Navigator

navigator标识浏览器的信息,可以通过navigator来识别不同的浏览器,但现在,navigator中大部分属性都没有什么使用价值了!唯一一个还有那么点价值的就是userAgent了,一起来看看:

html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<button id="btn">点我</button>
<script>
    // 由于ie老版本不支持let关键字,所以,声明变量还是用的var
    var btn = document.getElementById('btn');
    btn.onclick = function () {
        /*
        * userAgent:
        *   chrome  Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36
        *   firefox Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:82.0) Gecko/20100101 Firefox/82.0
        *   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     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)
        *   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)
        * */
        var ua = navigator.userAgent;
        if ('ActiveXObject' in window) { // ActiveXObject是ie独有的属性,可以判断当前浏览器的身份是否是ie
            alert('你是ie');
        } else if (ua.indexOf('Chrome') !== -1) { // 其他浏览器就可以去ua中判断是否包含对应的浏览器的名字了
            alert('你是chrome');
        } else if (ua.indexOf('Firefox') !== -1) {
            alert('你是Firefox');
        }

    };
</script>
</body>
</html>

Screen

https://www.w3school.com.cn/js/js_window_screen.asp

https://www.runoob.com/js/js-window-screen.html

window.screen 对象包含用户屏幕的信息,对我们来说,用的不多。

html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
<script>
    console.log(screen.width); // 返回以像素计的访问者屏幕宽度。
    console.log(screen.height); // 返回以像素计的访问者屏幕的高度。
    console.log(screen.availWidth); // 返回访问者屏幕的宽度,以像素计,减去诸如窗口工具条之类的界面特征。
    console.log(screen.availHeight); // 返回访问者屏幕的高度,以像素计,减去诸如窗口工具条之类的界面特征。
    console.log(screen.colorDepth); // 返回用于显示一种颜色的比特数。
    console.log(screen.pixelDepth); // 返回屏幕的像素深度。
</script>
</body>
</html>

that's all