• 全世界最短IE判定if(!+[1,])的解释(转)


    全世界最短IE判定if(!+[1,])的解释

     

    虽然从司徒先生的博客上看到 全世界最短的IE判定 很长时间了,却一直对于原理没怎么去细看,今天同事(也是一后台程序员,并非前端)又问到这个问题,于是我这个前端外行认真研究了下,基本弄懂了,贴在这里备份,高手就绕过吧,以免浪费时间

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    <script type="text/javascript">
    alert([1,2]);//相当于alert([1,2].toString()); --这在IE与非IE上都相同,都会弹出"1,2"
    alert([1,]);//相当于alert([1,].toString());--在非IE的标准浏览器上,js引擎会自动删除最后的",",所以在IE上会弹出"1,",而在非IE上会弹出"1"
    alert(+[1,]);//根据上面的解释,这一句在IE上相当于alert(+"1,"),而在非IE上相当于alert(+"1"),正号的作用在于试图将字符串转换为数字,"1,"当然不是数字,而"1"可以转换为数字1,所以最终的结果:IE上会转换失败弹出"NaN",而非IE浏览器上会弹出数字"1"
     
    //上面的+号转换字符串为数字的测试
    var s = +"5";
    alert(s+1);
     
    //ok,到这里为止,我们知道 +[1,] 最终在IE为上NaN,在非IE浏览器上则为数字1
     
    //下面再来看看很有个性的NaN
    alert(NaN==true);//弹出 false
    alert(NaN==false);//弹出 false
    alert(NaN==NaN);//弹出 false
     
    //即NaN不管与谁比较都是false
    alert(!NaN);//相当于alert(!(NaN==true)),根据上面的解释当然是弹出true
     
     
    //所以,alert(!+[1,]) 最终在IE上会弹出"true",下面再来看看firefox等非IE浏览器上的表现
    alert(new Boolean(0));//false
    alert(new Boolean(1));//true
    alert(new Boolean(-1));//true
    //即:数字0会转换为false,其它任何数字都会转换为true,所以最终在非IE浏览器上最终等效于:
    alert(!1);
    //即
    alert(!true)//最终会得到false
     
    //综上所述:下面的这个判断就能判定浏览器是不是IE
    if (!+[1,]){
        alert("我是货真价实的IE浏览器!")
    }
    else{
        alert("我不是IE!")
    }
    </script>

    注:随着时间的推移,IE9及以上版本已经修复了该BUG(除非设置成兼容模式),这一点在司徒的原文回复中也已经有人指出了。检测IE的方法有很多种,不一定非得用这种奇淫技巧,原文回复中,司徒还给出了另一种方法

    复制代码
    1             if ((!window.VBArray)){
    2                 alert("Not IE");
    3             }
    4             else{
    5                 alert("IE");
    6             }
    复制代码
    作者:菩提树下的杨过
    出处:http://yjmyzz.cnblogs.com 
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    Servlet编程寄语
    filter常用功能
    Javascript的自动、定时执行和取消
    CentOS 5安装GIT的基本命令
    EF调用执行Oracle中序列
    WCF使用IIS发布服务的配置
    linux 自学系列:debian更新软件列表、更改源
    shell编程笔记五:select
    linux 自学系列: 改IP地址,主机名及DNS
    shell编程笔记四:case in
  • 原文地址:https://www.cnblogs.com/thinkingthigh/p/4238011.html
Copyright © 2020-2023  润新知