BOM 浏览器对象模型_window.navigator
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的更多相关文章
- BOM 浏览器对象模型_window 对象的常见 window.属性_window.方法
1. 常用属性 window.devicePixelRatio 像素比 = css / 物理像素 window.scrollX,window.scrollY 滚动条 卷曲距离 if ...
- JavaScript——BOM(浏览器对象模型),时间间隔和暂停
BOM(浏览器对象模型):能够对浏览器的窗体进行訪问和操作 1.主要的BOM体系: window------------document-------------------------------- ...
- 第一百一十一节,JavaScript,BOM浏览器对象模型
JavaScript,BOM浏览器对象模型 学习要点: 1.window对象 2.location对象 3.history对象 BOM也叫浏览器对象模型,它提供了很多对象,用于访问浏览器的功能.BOM ...
- BOM浏览器对象模型
访问和操作浏览器窗口的模型称为浏览器对象模型BOM(Browser Object Model). BOM整体对象图. 核心是window对象: 以下有特殊双重身份: window对象既是ECMAScr ...
- JavaScript(二、BOM 浏览器对象模型)
一.BOM是什么 BOM是browser object model的缩写,简称浏览器对象模型 BOM提供了独立于内容而与浏览器窗口进行交互的对象 由于BOM主要用于管理窗口与窗口之间的通讯,因此其核心 ...
- BOM—浏览器对象模型(Browser Object Model)
1,javascript 组成部分: 1.ECMAscript(核心标准): 定义了基本的语法,比如:if for 数组 字符串 ... 2.BOM : 浏览器对象模型(Browser ...
- JS第三部分--BOM浏览器对象模型
一.client系列:宽高边框 二.offset系列:偏移 三.scroll系列 四.BOM的介绍 4.1.打开新窗口 4.2.location对象(本地信息对象) 4.3.history对象 4.4 ...
- js BOM浏览器对象模型
BOM即Browser Object Model,浏览器对象模型,表示浏览器窗口,所有js全局对象.函数以及变量均是window 对象的成员. 对于不同的浏览器,表示宽度和高度的方法不同: 对于IE9 ...
- JavaScirpt(JS)——BOM浏览器对象模型
一.BOM概念 BOM(Browser Object Model)即浏览器对象模型.可以对浏览器窗口进行访问和操作.使用 BOM,开发者可以移动窗口.改变状态栏中的文本以及执行其他与页面内容不直接相关 ...
随机推荐
- django - 总结 - 中间件
中间件顾名思义,是介于request与response处理之间的一道处理过程,相对比较轻量级,并且在全局上改变django的输入与输出.因为改变的是全局,所以需要谨慎实用,用不好会影响到性能. MID ...
- [物理学与PDEs]第4章第1节 引言
1. 本章讨论可燃流体在流动过程中同时伴随着燃烧现象的情况. 2. 燃烧有两种, 一种是爆燃 (deflagration): 火焰低速向前传播, 此时流体微元通常是未燃气体.已燃气体的混合物; 一 ...
- [物理学与PDEs]第2章第5节 一维流体力学方程组的 Lagrange 形式 5.2 Lagrange 坐标
1. Lagrange 坐标 $$\beex \bea &\quad 0=\int_\Omega\cfrac{\p \rho}{\p t}+\cfrac{\p}{\p x}(\rho u)\r ...
- react-router(v4) 路由跳转后返回页面顶部问题
遇到的问题 由A页面跳转到B页面,B页面停留在A页面的位置,没有返回到顶部. 问题分析 首先分析下出现此问题的原因: 在项目中使用的是 hashHistory,它是建立在 history 之上的,当路 ...
- Linux负载查询定位工具
1 uptime命令,负载查询命令 02:34:03 // 当前时间up 2 days, 20:14 // 系统运行时间1 user // 正在登录用户数 而最后三个数字呢,依次则是过去 1 分钟.5 ...
- 往服务器部署thinkphp5代码时要注意 pathinfo的问题
往服务器部署thinkphp5代码时要注意 pathinfo的问题 如果nginx没有做任何设置 要使用?s=/的方式访问地址 只需要修改3个地方就可以了,亲测成功,看代码有注解 location ~ ...
- 关闭VS警告 warning C4996
warning C4996: '_vsnprintf': This function or variable may be unsafe. ...... warning C4996: strcpy w ...
- php 两变量值互换 方法
//方法一:$a ="abc";$b="def"; $a = $a^$b;$b = $b^$a;$a = $a^$b; //方法二:list($a, $b)= ...
- WPF 单个触发器、多个触发器、多条件触发器
Trigger的使用.利用Trigger对象,我们可以接收到属性变化或者事件发生,并据此做出适当的响应.Trigger本身也是支持多种类型的,下面是一个属性Trigger的例子: <Style ...
- MUI初学1
1.1)官网: http://www.dcloud.io/ 2)案例: http://www.dcloud.io/case/#group-1 3)文档:http://dev.dcloud.net.cn ...