找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
积分等级发帖收益的说明江阴论坛帮助汇总江阴论坛管理规则(必看)江阴论坛版主招聘中江阴论坛已运行
查看: 1665|回复: 0

[技术分享] 全世界最短的 JavaScript 判定 IE 浏览器!

[复制链接]
发表于 2010-2-21 14:26:36 | 显示全部楼层 |阅读模式
有些东西你想让它长它并不一定就会如愿,但是有一些东西你想让它短也并不一定就会如愿,这两者都要看你的本事。对于我等IT民工来说,自然是代码写得越短越好。

你知道,IE是个脑残儿浏览器,不管是什么版本,纵使版本号越来越大,可总是让人觉得这玩意儿跟标准老是扯不上暧昧。可是,你知道,只要世上还有 windows 操作系统,IE就永生不灭,阿门。对于代码工作者来说,自然是苦不堪言,为了考虑IE的兼容问题,不管是写 CSS 还是 JS,往往都要对 IE 特别对待,这就少不了做些判断。本文不讨论如何区分 IE 的样式,仅是 JS 判定 IE 浏览器。

这个目前世界上最短的 Javascript 判定 IE 浏览器的方法来自一个俄人,又是俄人!它已经在各版本的 IE 以及目前其他流行的浏览器上经过测试,基于 IE 的 Bug,微软虽然已经意识到,但是从来没有纠正过。
  1. <script type='text/javascript'>
  2. var ie = !-[1,];
  3. alert(ie);
  4. </script>
复制代码
以上代码运行结果:IE 下返回true,其他标准浏览器返回false。!-[1,],仅仅只有 6 bytes!

不过如果反过来判断,标准浏览器返回 true 而 IE 返回 false的话,则可以再缩短一个byte。
  1. <script type='text/javascript'>
  2. notIe = -[1,];

  3. if(-[1,]){
  4. // 标准浏览器代码
  5. }else{
  6. // IE Only的代码
  7. }
  8. </script>
复制代码
看完了这些,你们是不是很好奇这些是怎么运行的?请继续看下文。

这个 Bug 产生的原因是 IE 会添加一个空数组元素到数组元素的总数里。
  1. [1,]. Length
复制代码
标准浏览器会返回 1 (基于标准的 ECMAscript ,在数组最后的逗号”,”会被忽略,这是为了方便在一列里显示以及自动生成等),但是 IE 会返回 2。当你打印这个数组的时候 IE 将会返回 “1, “,也就是两个元素,而其他标准浏览器将会返回 “1″。

这很容易验证,比如在 IE 和 FF中运行以下代码:
  1. <script type='text/javascript'>
  2. alert([,]==',');
  3. //这是8个字符判定IE
  4. </script>
复制代码
[1,]实际上浏览器的操作是toString()转换成字符串的操作,-[1,]是将字符串强制转换为数字。而 IE 将会返回 NaN,但是遗憾的是 NaN 并不是一个数字,因为[1,]转换成字符串后的”1,”里面带有逗号。而其他标准浏览器会返回 -1,这是一个非 0 的数字。

你知道,NaN 转换成 Boolean 型将返回 false,所以-[1,]在 IE 下将返回 false。而任何非 0 的数字转换成 Boolean 型(例如-1),在 标准浏览器下都将返回 true。所以我们得到了一个判定结果,!-[1,]在 IE 下返回true,而在其他标准浏览器下返回 false。也就达到了区分判定 IE 浏览器的目的。

当然,如前文所说,这个 Bug 其实微软很早就已经知道,但是却一直没有去修复它,所以在未来的 > IE8 的 IE 浏览器也就不确定是否依旧可以,不过基本上这么多代的 IE 都没有修复,未来的 IE 也不太会去修复的样子。

以下是其他的一些区分判定 IE 浏览器的代码,也可以参考下:
  1. <script type='text/javascript'>
  2. // Option from Dean Edwards:
  3. var ie = /*@cc_on!@*/false;

  4. // Use the commented line:
  5. var ie//@cc_on=1;

  6. // Variation (shorter variable):
  7. var ie = '\v'=='v';

  8. / / Option to Gareth Hayes (former record-holder):
  9. var ie = !+"\v1";
  10. </ script>
复制代码
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|江阴人家

GMT+8, 2024-12-28 21:08 , Processed in 0.289314 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表