window.navigator 对象

包含浏览器和系统信息的 Navigator 对象。

通过这个属性 了解用户的环境信息

window.navigator.userAgent

返回浏览器的 User Agent 字符串,表示浏览器的厂商和版本信息

用户可以改变这个字符串。

这个字符串的格式并无统一规定,也无法保证未来的适用性,各种上网设备层出不穷,难以穷尽。

所以,现在一般不再通过它识别浏览器了,

使用“功能识别”方法,即逐一测试当前浏览器是否支持要用到的 JavaScript 功能

  • 通过 userAgent 可以大致准确地识别 手机浏览器,方法就是测试是否包含 mobi 字符串
  • /mobi/i.test(userAgentStr);
  • /mobi|android|touch|mini/i.test(ua)

window.navigator.plugins

返回一个类似数组的对象,成员是 Plugin 实例对象,表示浏览器安装的插件,比如 Flash、ActiveX 等

  • var pluginsLength = navigator.plugins.length;
    
    for (var i = 0; i < pluginsLength; i++) {
    console.log(navigator.plugins[i].name);
    console.log(navigator.plugins[i].filename);
    console.log(navigator.plugins[i].description);
    console.log(navigator.plugins[i].version);
    }

5

window.navigator.platform

返回用户的操作系统信息,比如MacIntel、Win32、Linux x86_64等

  • navigator.platform
    // "Linux x86_64"

window.navigator.onLine

返回一个布尔值,表示用户当前在线还是离线

如果是false,可以断定用户一定离线

如果是 true,就不一定真的在线

  • 用户变成在线会触发 online 事件,变成离线会触发 offline 事件
  • window.addEventListener('offline', function(e) {
    console.log('offline');
    });
    window.addEventListener('online', function(e) {
    console.log('online');
    });

window.navigator.language

返回一个字符串,表示浏览器的首选语言。该属性只读

window.navigator.languages

返回一个数组,表示用户可以接受的语言

HTTP 请求头信息的 Accept-Language 字段,就来自这个数组

  • navigator.languages     // ["en-US", "en", "zh-CN", "zh", "zh-TW"]

window.navigator.geolocation

返回一个 Geolocation 对象,包含用户地理位置的信息

注意,该 API 只有在 HTTPS 协议下可用,否则调用下面方法时会报错

  • Geolocation 对象提供下面三个方法

window.navigator.geolocation.getCurrentPosition()

得到用户的当前位置

window.navigator.geolocation.watchPosition()

监听用户位置变化

window.navigator.geolocation.clearWatch()

取消 watchPosition() 指定的监听函数

  • 注意,调用这三个方法时,浏览器会跳出一个对话框,要求用户给予授权

window.navigator.cookieEnabled

属性返回一个布尔值,表示浏览器的 Cookie 功能是否打开

这个属性反映的是浏览器总的特性,与是否储存某个具体的网站的 Cookie 无关

用户可以设置某个网站不得储存 Cookie,这时 cookieEnabled 返回的还是 true

  • window.navigator.javaEnabled()

返回一个布尔值,表示浏览器是否能运行 Java Applet 小程

  • window.navigator.sendBeacon()

用于向服务器异步发送数据

window.screen 对象

表示当前窗口所在的屏幕,提供显示设备的信息

window.screen.width

浏览器窗口所在的屏幕的宽度(单位像素)。

window.screen.height

浏览器窗口所在的屏幕的高度(单位像素)

除非调整显示器的分辨率,否则这个值可以看作常量,不会发生变化。

显示器的分辨率与浏览器设置无关,缩放网页并不会改变分辨率。

window.screen.availWidth

浏览器窗口可用的屏幕宽度(单位像素)

window.screen.availHeight

浏览器窗口可用的屏幕高度(单位像素)

因为部分空间可能不可用,这个属性等于 height 减去那些被系统组件的高度。

比如系统的任务栏 或者 Mac 系统屏幕底部的 Dock 区

window.screen.pixelDepth

整数,表示屏幕的色彩位数

比如24表示屏幕提供24位色彩

window.screen.colorDepth

整数,表示应用程序的颜色深度

window.screen.orientation

返回一个对象,表示屏幕的方向

  • window.screen.orientation.type 属性是一个字符串,表示屏幕的具体方向

"landscape-primary"    表示横放

"landscape-secondary"    表示颠倒的横放

"portrait-primary"    表示竖放

"portrait-secondary"    表示颠倒的竖放

  • window.screen.orientation    // { angle: 0, type: "landscape-primary", onchange: null }
  • 保证屏幕分辨率大于 1024 x 768
  • if (window.screen.width >= 1024 && window.screen.height >= 768) {
    // 分辨率不低于 1024x768
    }
  • if ((screen.width <= 800) && (screen.height <= 600)) {
    window.location.replace('small.html');
    } else {
    window.location.replace('wide.html');
    }

BOM 浏览器对象模型_window.navigator的更多相关文章

  1. BOM 浏览器对象模型_window 对象的常见 window.属性_window.方法

    1. 常用属性 window.devicePixelRatio        像素比 = css / 物理像素 window.scrollX,window.scrollY    滚动条 卷曲距离 if ...

  2. JavaScript——BOM(浏览器对象模型),时间间隔和暂停

    BOM(浏览器对象模型):能够对浏览器的窗体进行訪问和操作 1.主要的BOM体系: window------------document-------------------------------- ...

  3. 第一百一十一节,JavaScript,BOM浏览器对象模型

    JavaScript,BOM浏览器对象模型 学习要点: 1.window对象 2.location对象 3.history对象 BOM也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能.BOM ...

  4. BOM浏览器对象模型

    访问和操作浏览器窗口的模型称为浏览器对象模型BOM(Browser Object Model). BOM整体对象图. 核心是window对象: 以下有特殊双重身份: window对象既是ECMAScr ...

  5. JavaScript(二、BOM 浏览器对象模型)

    一.BOM是什么 BOM是browser object model的缩写,简称浏览器对象模型 BOM提供了独立于内容而与浏览器窗口进行交互的对象 由于BOM主要用于管理窗口与窗口之间的通讯,因此其核心 ...

  6. BOM—浏览器对象模型(Browser Object Model)

     1,javascript   组成部分: 1.ECMAscript(核心标准):    定义了基本的语法,比如:if for 数组 字符串 ... 2.BOM  : 浏览器对象模型(Browser ...

  7. JS第三部分--BOM浏览器对象模型

    一.client系列:宽高边框 二.offset系列:偏移 三.scroll系列 四.BOM的介绍 4.1.打开新窗口 4.2.location对象(本地信息对象) 4.3.history对象 4.4 ...

  8. js BOM浏览器对象模型

    BOM即Browser Object Model,浏览器对象模型,表示浏览器窗口,所有js全局对象.函数以及变量均是window 对象的成员. 对于不同的浏览器,表示宽度和高度的方法不同: 对于IE9 ...

  9. JavaScirpt(JS)——BOM浏览器对象模型

    一.BOM概念 BOM(Browser Object Model)即浏览器对象模型.可以对浏览器窗口进行访问和操作.使用 BOM,开发者可以移动窗口.改变状态栏中的文本以及执行其他与页面内容不直接相关 ...

随机推荐

  1. linux下安装与配置Redis

    1.安装 (1)获取源代码 wget http://download.redis.io/releases/redis-4.0.8.tar.gz (2)解压 tar xzvf redis-4.0.8.t ...

  2. [物理学与PDEs]第3章第2节 磁流体力学方程组 2.1 考虑到导电媒质 (等离子体) 的运动对 Maxwell 方程组的修正

    1.  Maxwell 方程组 $$\bee\label{3_2_1_Maxwell} \bea \Div{\bf D}&=\rho_f,\\ \rot{\bf E}&=-\cfrac ...

  3. LINUX 常用命令(一)

    1.LINUX系统常用命令实例: A0 LINUX命令分内置命令和非内置命令! 一般而言,内置命令就是指在/bin ./usr/bin下系统默认的命令! 非内置命令需要加上命令的绝对路径执行!比如我们 ...

  4. sqlmap基础入门超详细教程

    前言: 总算进入了自己喜欢的行业. 要时刻记得当初自己说过的话, 不忘初心. Come on! 资料: 感谢超哥分享的干货..  sqlmap干货点击直达 学习环境: 本次学习使用的是kali集成的s ...

  5. Centos7 安装 jdk 1.8

    Centos7 安装 jdk 1.8 1.下载安装包 链接: https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloa ...

  6. ES6 + Webpack + React + Babel 如何在低版本浏览器上愉快的玩耍

    https://blog.csdn.net/a324539017/article/details/52824189

  7. 第三周 数据分析之概要 Pandas库数据特征分析

    数据的排序: 数据的基本统计分析 : 数据的累计统计分析: 数据的相关分析: 单元小结

  8. .\OBJ\test1.axf: Error: L6230W: Ignoring --entry command. Cannot find argumen 'Reset_Handler'

    原因是缺少了启动文件,startup_xxx.s,只需要把该文件添加到项目下即可,该文件如果找不到则重新建立工程,每个新的工程建立后系统都会询问是否添加启动文件,选择添加启动文件即可. 注意选择对应容 ...

  9. 1.2低级线程处理API

    并行扩展库相当有用,因为它允许使用更高级的抽象——任务,而不必直接和线程打交道.但有的时候,要处理的代码是在TPL和PLINQ问世(.NET4.0)之前写的.也有可能某个编程问题不能直接使用它们解决, ...

  10. Python-Django-BMS-增删改查

    无名分组 有名分组 反向解析 更改路由后不影响,动态传值 locals()传参 queryset.update() 自定义过滤器 {{forloop.counter}} new.authors.add ...