原文
简书原文:https://www.jianshu.com/p/fa7b95e02eea
大纲
1、什么是客户端检测
2、客户端检测的分类
3、能力检测
4、怪癖检测
5、用户代理检测
6、客户端检测方法的选择
1、什么是客户端检测
所谓客户端检测就是为了实现某种功能,但是不同的客户端对实现该功能的实现方式是不同的,因此需要通过对不同客户端的检测我们才能够针对不同的客户端采用不同的方式来实现相同的效果。
客户端检测是JavaScript开发中最具争议的一个话题。由于浏览器间存在差别,通常需要根据不同浏览器的能力分别编写不同的代码。
不同的客户端表示不同的性能,不同的处理方式,不同的客户端包括不同的平台、不同的浏览器(不同的浏览器采用不同的呈现内核、JavaScript解析内核等)
2、客户端检测的分类
客户端检测分为:能力检测、怪癖检测、用户代理检测
3、能力检测
在编写代码之前先检测特定浏览器的能力。例如,脚本在调用某个函数之前,可能要先检测该函数是否存在。这种检测方法将开发人员从考虑具体浏览器类型和版本中解放出来,让他们把注意力集中到相应的能力是否存在上。能力检测无法精确地检测特定的浏览器和版本。
4、怪癖检测
怪癖实际上是浏览器实现中存在的bug,例如早期的WebKit中就存在一个怪癖,即它会在for-in循环中返回被隐藏的属性。怪癖检测通常涉及到运行一小段代码,然后确定浏览器是否存在某个怪癖。由于怪癖检测与能力检测相比效率更低,因此应该只在某个怪癖会干扰脚本运行的情况下使用。怪癖检测无法精确的检测特定的浏览器和版本。
5、用户代理检测
通过检测用户代理字符串来识别浏览器。用户代理字符串中包含大量与浏览器有关的信息,包括浏览器、平台、操作系统及浏览器版本。用户代理字符串有过一段相当漫长的发展历史,在此期间,浏览器提供商试图通过在用户代理字符串中添加一些欺骗性信息,欺骗网站相信自己的浏览器是另外一种浏览器。用户代理检测需要特殊的技巧,特别是要注意Opera会隐藏其用户代理字符串的情况。即便如此,通过用户代理字符串仍然能够检测出浏览器所使用的呈现引擎以及所在的平台,包括移动设备和游戏系统。
6、客户端检测方法的选择
在决定使用哪种客户端检测方法时,一般应优先考虑使用能力检测。怪癖检测是确定应该如何处理代码的第二选择。而用户代理检测则是客户端检测的最后一种方案,因为这种方法对用户代理字符串具有很强的依赖性。