Webcourse/04-JavaScript基础/31-BOM简介&Navigator.md
2019-11-27 19:29:49 +08:00

4.6 KiB
Raw Blame History

常见概念

JavaScript的组成

JavaScript基础分为三个部分

  • ECMAScriptJavaScript的语法标准。包括变量、表达式、运算符、函数、if语句、for语句等。

  • DOM文档对象模型Document object Model操作网页上的元素的API。比如让盒子移动、变色、轮播图等。

  • BOM浏览器对象模型Browser Object Model操作浏览器部分功能的API。比如让浏览器自动滚动。

常见的 BOM 对象

BOM可以让我们通过JS来操作浏览器。BOM中为我们提供了一些对象来完成对浏览器相关的操作。

常见的 BOM对象有

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

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

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

  • History代表浏览器的历史记录通过该对象可以操作浏览器的历史记录。由于隐私原因该对象不能获取到具体的历史记录只能操作浏览器向前或向后翻页而且该操作只在当次访问时有效。

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

备注:这些 BOM 对象都是作为 window 对象的属性保存的可以通过window对象来使用也可以直接使用。比如说我可以使用 window.location.href,也可以直接使用 location.href,二者是等价的。

备注2不要忘了之前学习过的document也是在window中保存的。

这篇文章,我们先来讲一下 Navigator

Navigator 和 navigator.userAgent

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

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

一般我们只会使用navigator.userAgent来获取浏览器的信息

userAgent 的值是一个字符串,简称 UA这个字符串中包含了用来描述浏览器信息的内容不同的浏览器会有不同的userAgent。

代码举例获取当前浏览器的UA

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>Document</title>
    </head>
    <body>
        <script>
            var ua = navigator.userAgent; // 获取当前浏览器的 userAgent

            console.log('qianguyihao 当前浏览器的UA是' + ua);

            if (/firefox/i.test(ua)) {
                alert('是火狐浏览器');
            } else if (/chrome/i.test(ua)) {
                alert('是Chrome浏览器');
            } else if (/msie/i.test(ua)) {
                alert('是IE浏览器');
            } else if ('ActiveXObject' in window) {
                alert('是 IE11 浏览器');
            }
        </script>
    </body>
</html>

在电脑上模拟移动端浏览器

不同浏览器(包括微信内置的浏览器)的 userAgent 信息,是不一样的,我们可以根据 navigator.userAgent属性来获取。

比如说我们在电脑浏览器上按F12然后在控制台输入navigator.userAgent,如下:

上图显示MacOS上的Chrome浏览器的 userAgent 是:

"Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/66.0.3359.117 Safari/537.36"

我们还可以在电脑浏览器的控制台里可以添加很多设备,通过这种方式,可以模拟移动端浏览器的场景,非常有用,请务必掌握。操作如下:

1需要点击 edit手动添加

2添加时根据 User agent 来识别不同的浏览器:

不同浏览器的 userAgent

iPhone版微信浏览器

Mozilla/5.0 (iPhone; CPU iPhone OS 9_3 like Mac OS X) AppleWebKit/601.1.46 (KHTML, like Gecko) Mobile/13E233 MicroMessenger/6.3.15 NetType/WIFI Language/zh_CN

Android版微信浏览器

Mozilla/5.0 (Linux; Android 5.0.1; GT-I9502 Build/LRX22C; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/43.0.2357.121 Mobile Safari/537.36 MicroMessenger/6.1.0.78_r1129455.543 NetType/WIFI

参考链接