js中两个感叹号的原理与用法分析(转载记录没找到原帖)

var foo;  
alert(!foo);//undifined情况下,一个感叹号返回的是true;  
alert(!goo);//null情况下,一个感叹号返回的也是true;  
var o={flag:true};  
var test=!!o.flag;//等效于var test=o.flag||false;  
alert(test); 

 

  这段例子,演示了在undifined和null时,用一个感叹号返回的都是true,用两个感叹号返回的就是false,所以两个感叹号的作用就在于, 如果明确设置了变量的值(非null/undifined/0/""等值),结果就会根据变量的实际值来返回,如果没有设置,结果就会返回false。

    grep: function( elems, callback, inv ) {  
            var ret = [], retVal;  
            inv = !!inv;  
      
            // Go through the array, only saving the items  
            // that pass the validator function  
            for ( var i = 0, length = elems.length; i < length; i++ ) {  
                retVal = !!callback( elems[ i ], i );  
                if ( inv !== retVal ) {  
                    ret.push( elems[ i ] );  
                }  
            }  
      
            return ret;  
        }  

  这是jquery中一个比较经典的例子,

     在使用grep函数的时候,如果给出了第三个参数且非null/undefined/0""/等值,则inv为     true,否则为false。这样做的目的就是保证inv和retVal的值都只能在true/false中取,而非其它值,为后续判断提供便利。

posted @ 2015-01-20 11:53  me春天  阅读(187)  评论(0编辑  收藏  举报