摘要:由于那个时候是霸主,这也导致微软推出的时候必须把自己伪装成浏览器,于是他们的也是以开头的。各个版本典型的如下其中之后的就是当前的版本号。的几个版本的其中之后的是版本号提供了专门的浏览器标志,就是属性。目前,的是其中,版本号在之后的数字。
浏览器嗅探
浏览器嗅探不用说了,为了更好的性能,会需要各种各样的兼容性处理,自然就会有针对不同浏览器的判断.
一般的代码中,我们都是通过navigator.userAgent来判断不同的浏览器的情况的。
火狐:
chrome:
ie8:
sougou高速:
sougou兼容:
首先为什么全部都是Mozilla打头,而后后面的一堆内容都是什么,我们获取浏览器是什么,版本号是什么,当前是什么设备,当前是什么操作系统,分别应该从哪个字段里面判断呢?
为什么都是Mozilla打头
最早的时候,Netscape 把他们浏览器中的 User-Agent 定成了 Mozilla/4.04 (Macintosh; I; PPC) 的形式。由于里面包含了引擎名和版本信息,那个时候很多做网站的程序员就利用 User-Agent 来判断浏览器特性(比如是否支持 frame 等),对于他们认为不符合要求的浏览器显示不兼容内容(就像现在程序员歧视 IE 6 那样)。
由于那个时候 Netscape 是霸主,这也导致微软推出 IE 的时候必须把自己伪装成 Netscape 浏览器,于是他们的 User-Agent 也是以 Mozilla/4.0 开头的。(当然微软成为霸主之后就用一句「for historical reasons」淡定地带过此历史。)后来这也就成为了事实标准,所有主要浏览器都以 Mozilla/x.0 开头了。
参考:https://msdn.microsoft.com/en-us/library/ms537503%28v=vs.85%29;http://www-archive.mozilla.org/build/user-agent-strings.html
详细的各个浏览器的各个字段的意义
基本上大概是这样的,但是浏览器的世界你懂得,还是有各种各样的。
已经有不少人整理里,不贴了,移步查看
http://www.cnblogs.com/georgewing/archive/2010/01/18/1650960.html
那么好吧,知道这么多,怎么破,怎么做各种各样的判断呢?
我们先来分析一下各种浏览器的特征及其userAgent
IE只有IE支持创建ActiveX控件,因此,ActiveObject函数可以作为判断标准。
IE各个版本典型的userAgent如下:
Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.0)
Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2)
Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1)
Mozilla/4.0 (compatible; MSIE 5.0; Windows NT)
其中MSIE之后的就是当前ie的版本号。
FirefoxFirefox中的DOM元素有这么个getBoxObjectFor函数,用来获取DOM元素的位置和大小。这是Firefoxd独有的,so,你懂得。
Firefox的几个版本的userAgent:
Mozilla/5.0 (Windows; U; Windows NT 5.2) Gecko/2008070208 Firefox/3.0.1
Mozilla/5.0 (Windows; U; Windows NT 5.1) Gecko/20070309 Firefox/2.0.0.3
Mozilla/5.0 (Windows; U; Windows NT 5.1) Gecko/20070803 Firefox/1.5.0.12
其中Firefox之后的是版本号
OperaOpera提供了专门的浏览器标志,就是window.opera属性。Opera典型的userAgent如下:
Opera/9.27 (Windows NT 5.2; U; zh-cn)
Opera/8.0 (Macintosh; PPC Mac OS X; U; en)
Mozilla/5.0 (Macintosh; PPC Mac OS X; U; en) Opera 8.0
Safari浏览器中有一个其他浏览器没有的openDatabase函数,可做为判断Safari的标志。Safari典型的userAgent如下
Mozilla/5.0 (Windows; U; Windows NT 5.2) AppleWebKit/525.13 (KHTML, like Gecko) Version/3.1 Safari/525.13
Mozilla/5.0 (iPhone; U; CPU like Mac OS X) AppleWebKit/420.1 (KHTML, like Gecko) Version/3.0 Mobile/4A93 Safari/419.3
其版本号是Version之后的数字。
ChromeChrome有一个MessageEvent函数,但Firefox也有。不过,好在Chrome并没有Firefox的getBoxObjectFor函数,根据这个条件还是可以准确判断出Chrome浏览器的。目前,Chrome的userAgent是:
Mozilla/5.0 (Windows; U; Windows NT 5.2) AppleWebKit/525.13 (KHTML, like Gecko) Chrome/0.2.149.27 Safari/525.13
其中,版本号在Chrome之后的数字。
代码奉上普通青年
var Sys = {}; var ua = navigator.userAgent.toLowerCase(); var s; (s = ua.match(/msie ([d.]+)/)) ? Sys.ie = s[1] : (s = ua.match(/firefox/([d.]+)/)) ? Sys.firefox = s[1] : (s = ua.match(/chrome/([d.]+)/)) ? Sys.chrome = s[1] : (s = ua.match(/opera.([d.]+)/)) ? Sys.opera = s[1] : (s = ua.match(/version/([d.]+).*safari/)) ? Sys.safari = s[1] : 0; //以下进行测试 if (Sys.ie) document.write("IE: " + Sys.ie); if (Sys.firefox) document.write("Firefox: " + Sys.firefox); if (Sys.chrome) document.write("Chrome: " + Sys.chrome); if (Sys.opera) document.write("Opera: " + Sys.opera); if (Sys.safari) document.write("Safari: " + Sys.safari);
以上方法好看好懂,基本的模板实现,均是这种标准
文艺青年
var Sys = {};
var ua = navigator.userAgent.toLowerCase(); if (window.ActiveXObject) Sys.ie = ua.match(/msie ([d.]+)/)[1] else if (document.getBoxObjectFor) Sys.firefox = ua.match(/firefox/([d.]+)/)[1] else if (window.MessageEvent && !document.getBoxObjectFor) Sys.chrome = ua.match(/chrome/([d.]+)/)[1] else if (window.opera) Sys.opera = ua.match(/opera.([d.]+)/)[1] else if (window.openDatabase) Sys.safari = ua.match(/version/([d.]+)/)[1]; //以下进行测试 if(Sys.ie) document.write("IE: "+Sys.ie); if(Sys.firefox) document.write("Firefox: "+Sys.firefox); if(Sys.chrome) document.write("Chrome: "+Sys.chrome); if(Sys.opera) document.write("Opera: "+Sys.opera); if(Sys.safari) document.write("Safari: "+Sys.safari);
文艺方法,高效率,知道的知识点需要更多,但是不好读,别人拿到估计会不太高兴的。
touch设备的检测连买带送
var navigator = window.navigator, userAgent = navigator.userAgent, android = userAgent.match(/(Android)[s/]+([d.]+)/), ios = userAgent.match(/(iPad|iPhone|iPod)s+OSs([d_.]+)/), wp = userAgent.match(/(Windowss+Phone)s([d.]+)/), isWebkit = /WebKit/[d.]+/i.test(userAgent), isSafari = ios ? (navigator.standalone ? isWebkit: (/Safari/i.test(userAgent) && !/CriOS/i.test(userAgent) && !/MQQBrowser/i.test(userAgent))) : false, os = {}; if (android) { os.android = true; os.version = android[2]; } if (ios) { os.ios = true; os.version = ios[2].replace(/_/g, "."); os.ios7 = /^7/.test(os.version); if (ios[1] === "iPad") { os.ipad = true; } else if (ios[1] === "iPhone") { os.iphone = true; os.iphone5 = screen.height == 568; } else if (ios[1] === "iPod") { os.ipod = true; } } if (wp) { os.wp = true; os.version = wp[2]; os.wp8 = /^8/.test(os.version); } if (isWebkit) { os.webkit = true; } if (isSafari) { os.safari = true; } return os;
好不好用,自己试试
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/79678.html
摘要:事件详细研究边界事件外链样式在某些浏览器下面会影响脚本的加载。事件和事件是同时的。这就是要监听页面的事件,当事件为时就可以开始做的事情了。 页面加载状态 $(document).ready() $(function(){}) 这两个是我们在页面初始化时经常使用的监听方案,那么他的实际的执行关系时什么样的呢?在原生js中是什么样的一种表现? 以下我会一而再再而三的写DOMConten...
摘要:事件详细研究边界事件外链样式在某些浏览器下面会影响脚本的加载。事件和事件是同时的。这就是要监听页面的事件,当事件为时就可以开始做的事情了。 页面加载状态 $(document).ready() $(function(){}) 这两个是我们在页面初始化时经常使用的监听方案,那么他的实际的执行关系时什么样的呢?在原生js中是什么样的一种表现? 以下我会一而再再而三的写DOMConten...
摘要:抛开一直写的那个不讲,我们说的是一个简单的模块加载器的简单实现。非常好实现,忽略不提。是第一个冒出来的,但是,一般提到他都会是弃用的,会有安全的漏洞更好的方案是构造器。 什么是模块化,为什么要模块化 装个b,贴一段English A beginning programmer writes her programs like an ant builds her hill, one pie...
摘要:说明的核心容器有一部分就是利用反射来实现依赖注入时类的实例化。这是一个简化版示例。 说明 Laravel的核心容器,有一部分就是利用反射来实现依赖注入时类的实例化。这是一个简化版示例。 代码 测试用的类 /** * 坦克标准: 必须能开火 */ interface Tank { public function fire(); } /** * 59坦克,使用100毫米炮...
阅读 2097·2021-11-24 09:39
阅读 1564·2021-10-11 10:59
阅读 2509·2021-09-24 10:28
阅读 3383·2021-09-08 09:45
阅读 1275·2021-09-07 10:06
阅读 1672·2019-08-30 15:53
阅读 2068·2019-08-30 15:53
阅读 1427·2019-08-30 15:53