当我想检测IE时,我使用以下代码:
function getInternetExplorerVersion()
{
var rv = -1;
if (navigator.appName == 'Microsoft Internet Explorer')
{
var ua = navigator.userAgent;
var re = new RegExp("MSIE ([0-9]{1,}[\.0-9]{0,})");
if (re.exec(ua) != null)
rv = parseFloat( RegExp.$1 );
}
return rv;
}
function checkVersion()
{
var msg = "You're not using Internet Explorer.";
var ver = getInternetExplorerVersion();
if ( ver > -1 )
{
msg = "You are using IE " + ver;
}
alert( msg );
}
但是IE11返回“您没有使用Internet Explorer”。我如何检测它?
从User-Agent获取IE版本
var ie = 0;
try { ie = navigator.userAgent.match( /(MSIE |Trident.*rv[ :])([0-9]+)/ )[ 2 ]; }
catch(e){}
工作原理:所有IE版本的用户代理字符串都包含一部分“MSIE空间版本”或“Trident其他文本rv空格或冒号版本”。知道了这一点,我们从String.match()正则表达式中获取版本号。try-catch块用于缩短代码,否则我们需要测试非ie浏览器的数组边界。
注意:如果用户将浏览器设置为“兼容模式”,用户代理可能会被欺骗或省略,有时是无意的。尽管这在实践中似乎不是什么大问题。
获取没有User-Agent的IE版本
var d = document, w = window;
var ie = ( !!w.MSInputMethodContext ? 11 : !d.all ? 99 : w.atob ? 10 :
d.addEventListener ? 9 : d.querySelector ? 8 : w.XMLHttpRequest ? 7 :
d.compatMode ? 6 : w.attachEvent ? 5 : 1 );
工作原理:每个版本的IE都增加了对以前版本中没有的额外功能的支持。因此,我们可以以自顶向下的方式测试特性。为了简洁起见,这里使用了三元序列,不过if-then和switch语句也同样有效。变量ie被设置为整数5-11,旧的为1,新/非ie为99。如果你只是想测试IE 1-11,你可以把它设置为0。
注意:如果您的代码运行在带有第三方脚本的页面上,这些脚本为document.addEventListener之类的东西添加了腻子,那么对象检测可能会中断。在这种情况下,用户代理是最好的选择。
检测浏览器是否是现代的
如果你只对浏览器是否支持大多数HTML 5和css3标准感兴趣,你可以合理地假设ie8及更低版本的应用程序仍然是主要的问题应用程序。测试窗口。getComputedStyle会给你一个相当好的现代浏览器的组合,以及(IE 9, FF 4, Chrome 11, Safari 5, Opera 11.5)。IE 9大大提高了对标准的支持,但原生CSS动画需要IE 10。
var isModernBrowser = ( !document.all || ( document.all && document.addEventListener ) );
IE11不再报告为MSIE,根据这个更改列表,它是故意避免错误检测。
如果你真的想知道它是IE,你可以做的是在用户代理if导航器中检测Trident/字符串。appName返回Netscape,类似于(未测试的);
function getInternetExplorerVersion()
{
var rv = -1;
if (navigator.appName == 'Microsoft Internet Explorer')
{
var ua = navigator.userAgent;
var re = new RegExp("MSIE ([0-9]{1,}[\\.0-9]{0,})");
if (re.exec(ua) != null)
rv = parseFloat( RegExp.$1 );
}
else if (navigator.appName == 'Netscape')
{
var ua = navigator.userAgent;
var re = new RegExp("Trident/.*rv:([0-9]{1,}[\\.0-9]{0,})");
if (re.exec(ua) != null)
rv = parseFloat( RegExp.$1 );
}
return rv;
}
console.log('IE version:', getInternetExplorerVersion());
请注意,IE11 (afaik)仍处于预览阶段,用户代理在发布前可能会发生变化。