首页 > 其他分享 >Navigator 对象,Screen 对象。

Navigator 对象,Screen 对象。

时间:2022-10-04 10:31:21浏览次数:48  
标签:浏览器 对象 Screen window Navigator navigator 属性

Navigator 对象,Screen 对象。_数组

作者 | 阮一峰


​window.navigator​​属性指向一个包含浏览器和系统信息的 Navigator 对象。脚本通过这个属性了解用户的环境信息。

1、Navigator 对象的属性

1.1、Navigator.userAgent

​navigator.userAgent​​属性返回浏览器的 User Agent 字符串,表示浏览器的厂商和版本信息。

下面是 Chrome 浏览器的​​userAgent​​。

​​navigator.userAgent
// "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/29.0.1547.57 Safari/537.36"​​

通过​​userAgent​​属性识别浏览器,不是一个好办法。因为必须考虑所有的情况(不同的浏览器,不同的版本),非常麻烦,而且用户可以改变这个字符串。这个字符串的格式并无统一规定,也无法保证未来的适用性,各种上网设备层出不穷,难以穷尽。所以,现在一般不再通过它识别浏览器了,而是使用“功能识别”方法,即逐一测试当前浏览器是否支持要用到的 JavaScript 功能。

不过,通过​​userAgent​​​可以大致准确地识别手机浏览器,方法就是测试是否包含​​mobi​​字符串。

​​var ua = navigator.userAgent.toLowerCase();
if (/mobi/i.test(ua)) {
// 手机浏览器
} else {
// 非手机浏览器
}​​

如果想要识别所有移动设备的浏览器,可以测试更多的特征字符串。

​​/mobi|android|touch|mini/i.test(ua)​​

1.2、Navigator.plugins

​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);
}​​

1.3、Navigator.platform

​Navigator.platform​​​属性返回用户的操作系统信息,比如​​MacIntel​​​、​​Win32​​​、​​Linux x86_64​​等 。

​​navigator.platform
// "Linux x86_64"​​

1.4、Navigator.onLine

​navigator.onLine​​属性返回一个布尔值,表示用户当前在线还是离线(浏览器断线)。

​​navigator.onLine // true​​

有时,浏览器可以连接局域网,但是局域网不能连通外网。这时,有的浏览器的​​onLine​​​属性会返回​​true​​​,所以不能假定只要是​​true​​​,用户就一定能访问互联网。不过,如果是​​false​​,可以断定用户一定离线。

用户变成在线会触发​​online​​​事件,变成离线会触发​​offline​​​事件,可以通过​​window.ononline​​​和​​window.onoffline​​指定这两个事件的回调函数。

​​window.addEventListener('offline', function(e) { console.log('offline'); });
window.addEventListener('online', function(e) { console.log('online'); });​​

1.5、Navigator.language,Navigator.languages

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

​​navigator.language // "en"​​

​Navigator.languages​​​属性返回一个数组,表示用户可以接受的语言。​​Navigator.language​​​总是这个数组的第一个成员。HTTP 请求头信息的​​Accept-Language​​字段,就来自这个数组。

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

如果这个属性发生变化,就会在​​window​​​对象上触发​​languagechange​​事件。

1.6、Navigator.geolocation

​Navigator.geolocation​​属性返回一个 Geolocation 对象,包含用户地理位置的信息。注意,该 API 只有在 HTTPS 协议下可用,否则调用下面方法时会报错。

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

  • Geolocation.getCurrentPosition():得到用户的当前位置
  • Geolocation.watchPosition():监听用户位置变化
  • Geolocation.clearWatch():取消​​watchPosition()​​方法指定的监听函数

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

1.7、Navigator.cookieEnabled

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

​​navigator.cookieEnabled // true​​

注意,这个属性反映的是浏览器总的特性,与是否储存某个具体的网站的 Cookie 无关。用户可以设置某个网站不得储存 Cookie,这时​​cookieEnabled​​​返回的还是​​true​​。

2、Navigator 对象的方法

2.1、Navigator.javaEnabled()

​Navigator.javaEnabled()​​方法返回一个布尔值,表示浏览器是否能运行 Java Applet 小程序。

​​navigator.javaEnabled() // false​​

2.2、Navigator.sendBeacon()

​Navigator.sendBeacon()​​方法用于向服务器异步发送数据,详见《XMLHttpRequest 对象》一章。

3、Screen 对象

Screen 对象表示当前窗口所在的屏幕,提供显示设备的信息。​​window.screen​​属性指向这个对象。

该对象有下面的属性。

  • ​Screen.height​​:浏览器窗口所在的屏幕的高度(单位像素)。除非调整显示器的分辨率,否则这个值可以看作常量,不会发生变化。显示器的分辨率与浏览器设置无关,缩放网页并不会改变分辨率。
  • ​Screen.width​​:浏览器窗口所在的屏幕的宽度(单位像素)。
  • ​Screen.availHeight​​:浏览器窗口可用的屏幕高度(单位像素)。因为部分空间可能不可用,比如系统的任务栏或者 Mac 系统屏幕底部的 Dock 区,这个属性等于​​height​​减去那些被系统组件的高度。
  • ​Screen.availWidth​​:浏览器窗口可用的屏幕宽度(单位像素)。
  • ​Screen.pixelDepth​​:整数,表示屏幕的色彩位数,比如​​24​​表示屏幕提供24位色彩。
  • ​Screen.colorDepth​​:​​Screen.pixelDepth​​的别名。严格地说,colorDepth 表示应用程序的颜色深度,pixelDepth 表示屏幕的颜色深度,绝大多数情况下,它们都是同一件事。
  • ​Screen.orientation​​:返回一个对象,表示屏幕的方向。该对象的​​type​​属性是一个字符串,表示屏幕的具体方向,​​landscape-primary​​表示横放,​​landscape-secondary​​表示颠倒的横放,​​portrait-primary​​表示竖放,​​portrait-secondary​​。

下面是​​Screen.orientation​​的例子。

​​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');
}​​



Navigator 对象,Screen 对象。_数组_02

Navigator 对象,Screen 对象。_java_03

标签:浏览器,对象,Screen,window,Navigator,navigator,属性
From: https://blog.51cto.com/u_15809510/5731115

相关文章

  • 实验一 类和对象
    #include<iostream>#include<iomanip>usingstd::cout;usingstd::endl;classPoint{public:Point(intx0=0,inty0=0);Point(constPoint&......
  • 动手动脑 类和对象
      两个结果不同,第一个为false,第二个为true 可以推断出对象obj1是引用类型,==判断的是地址是否相等,要想判断内容是否相等要重写equals方法,因为类没有声明继承的话......
  • 关于 SAP UI5 ODataModel.createEntry 返回的 context 对象
    在返回的上下文中使用创建的API返回的Promise对象,以便在持久化或重置时获得通知。使用isTransientAPI,您可以确定创建的上下文是transient的还是持久的;请注意,对于尚......
  • Java对象序列化和反序列化
    Java类的序列化和反序列化序列化:指将对象转换为字节序列的过程,也就是将对象的信息转换成文件保存。反序列化:将字节序列转换成目标对象的过程,也就是读取文件,并转换为对象。几......
  • 实验1类和对象(1)
    1.实验任务11.template指的是模板。比如,我们要写一个swap函数来交换两个元素。但这两个元素可能是int也可能使char,如果不用模板的话,我们可能要写多个函数才能完成。但是......
  • 建民老师有关类和对象动手动脑的实践性报告
    有关动手动脑的实验性总结1.P29首先定义了一个类Foo,在这个类中包含数据成员value以及有参构造函数Foo(intinitValue);在Test类中用Foo类的无参构造方法去创建一个实......
  • 实验1 类和对象(1)
    1.实验任务1task1_1程序源码#include<iostream>#include<string>#include<vector>intmain(){usingnamespacestd;strings1;strings2{"cp......
  • 实验一 类与对象
    试验任务一task1:#include<iostream>#include<string>#include<vector>intmain(){usingnamespacestd;strings1;//创建一个string对象stri......
  • 实验一 类与对象(1)
    实验二:代码如下: #include<iostream>usingnamespacestd;classPoint{public:Point(intx0=0,inty0=0);Point(constPoint&p);......
  • 4、STL-函数对象
    4、STL-函数对象4.1函数对象4.1.1函数对象概念概念:重载函数调用操作符的类,其对象常称为函数对象函数对象使用重载()的时候,行为类似函数调用,也叫仿函数本质:函数对......