博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
《JavaScript高级程序设计》笔记:客户端检测(九)
阅读量:5006 次
发布时间:2019-06-12

本文共 2945 字,大约阅读时间需要 9 分钟。

能力检测

在编写代码之前先检测特定浏览器的能力。例如,脚本在调用某个函数之前,可能要先检测该函数首付存在。这种检测方法将开发人员从考虑具体的浏览器类型和版本中解放出来,让他们把注意力集中到相应的能力是否存在上。能力检测无法精确地检测特定的浏览器和版本。

怪癖检测

怪癖实际上是浏览器实现中存在的bug,例如早期的webkit中就存在一个怪癖,即它会再for-in循环中返回被隐藏的属性。怪癖检测通常涉及到运行一段代码,然后确定浏览器是否存在某个怪癖。由于怪癖检测无法精确地检测特定的浏览器和版本。

用户代理检测

通过检测用户代理字符串来识别浏览器。用户代理字符串中包含大量与浏览器有关的信息,包括浏览器、平台、操作系统及浏览器版本。用户代理字符串有过一段相当长的发展历史,在此期间,浏览器提供商视图通过在用户代理字符串总添加一些欺骗性信息,欺骗网站详细自己的浏览器是另外一种浏览器。用户代理检测需要特殊的技巧,特别是要注意Opera会隐瞒其用户代理字符串的情况。即便如此,通过用户代理字符串仍然能够检测出浏览器所用的呈现引擎以及所在的平台,包括移动设备和游戏系统。

在每一次HTTP请求过程中,用户代理字符串是作为响应首部发送的,而且该字符串可以通过Javascript的navigator.userAgent属性访问。在服务器端,通过检测用户代理字符串来确定用户使用的浏览器是一种常用而且广为接受的做法。而在客户端,用户代理检测一般被当作一种万不得已的做法,其优先级排在能力检测和怪癖检测之后。

var client = function(){    // 呈现引擎    var engine = {        ie:0,        gecko:0,        webkit:0,        khtml:0,        opera:0,        // 完整的版本号        ver:null    };    // 浏览器    var browser = {        // 主要浏览器        ie:0,        firefox:0,        safari:0,        konq:0,        opera:0,        chrome:0,        // 具体的版本号        ver:null    };    // 检测呈现引擎和浏览器    var ua = navigator.userAgent;    if (window.opera) {        engine.ver = browser.ver = window.opera.version();        engine.opera = browser.opera = parseFloat(engine.ver);    } else if (/AppleWebKit\/(\S+)/.test(ua)) {        engine.ver = RegExp["$1"];        engine.webkit = parseFloat(engine.ver);        // 确定是Chrome还是Safari        if (/Chrome\/(\S+)/.test(ua)) {            browser.ver = RegExp["$1"];            browser.chrome = parseFloat(engine.ver);        } else if (/Version\/(S+)/.test(ua)) {            browser.ver = RegExp["$1"];            browser.safari = parseFloat(browser.ver);        } else {            // 近似地确定版本号            var safariVersion = 1;            if (engine.Webkit <100) {                safariVersion = 1;            } else if (engine.webkit < 312) {                safariVersion = 1.2;            } else if (engine.webkit < 412) {                safariVersion = 1.3;            } else {                safariVersion = 2;            }            browser.safari = browser.ver = safariVersion;        }    } else if (/KHTML\/(S+)/.test(ua) || /Konqueror\/([^;]+)/.test(ua)) {        engine.ver = browser.ver = RegExp["$1"];        engine.khtml = browser.kong = parseFloat(engine.ver);    } else if (/rv:([^\)]+)\) Gecko\/\d{8}/.test(ua)){        engine.ver = RegExp["$1"];        engine.gecko = parseFloat(engine.ver);        // 确定是不是firefox        if (/Firefox\/(S+)/.test(ua)) {            browser.ver = RegExp["$1"];            browser.firefox = parseFloat(browser.ver);        }    } else if (/MSIE ([^;]+)/.test(ua)) {        engine.ver = browser.ver = RegExp["$1"];        engine.ie = browser.ie = parseFloat(engine.ver);    }    // 检测浏览器    browser.ie = engine.ie;    browser.opera = engine.opera;    // 返回这些对象    return {        engine:engine,        browser: browser    }}();console.log(client.engine);console.log(client.browser);

 

转载于:https://www.cnblogs.com/moqiutao/p/10107603.html

你可能感兴趣的文章
跨浏览器问题的五种解决方案
查看>>
XPath定位时,使用文本的方法小技巧。
查看>>
数学计算公式
查看>>
Hibernate学习(二补充)关系映射----基于外键的双向一对一
查看>>
开发记录04
查看>>
安装pandas报错(AttributeError: 'module' object has no attribute 'main')
查看>>
ch02 fundamental definition 01
查看>>
JSON解析
查看>>
Position is everything?(css定位学习的一些心得)(一)
查看>>
如何提高编程水平
查看>>
Jquery Uploadify3.21.与2.1版本 使用中存在的问题--记录三
查看>>
Linux查看进程的内存占用情况 分类: ubuntu ...
查看>>
[BZOJ 2818]Gcd
查看>>
FORM值传递与地址传递
查看>>
(译)yaml快速教程
查看>>
C:大数相加
查看>>
静态博客教程 1:hexo + github
查看>>
160. Intersection of Two Linked Lists
查看>>
人生苦短,我用python-- Day11
查看>>
JAVA Bean
查看>>