短路运算(逻辑运算是短路运算中最常见的一种)

写在前面的知识:

Boolean强制转换:

除了NaN、null、""、undefined、0、function这几个为false外,其他皆为true;

关于转换,等会我会再写一篇,专门讲string、int、Boolean转换。

 

 

短路运算的符号:    ||   &&  !  或与非

 

短路运算的原理:当有多个表达式时,左边的表达式值可以确定结果时,就不再继续运算右边的表达式的值;

 

短路运算的规则:

&& 找假,先看第一个表达式的值,如果第一个表达式不是布尔类型,强制转换成布尔类型,转换若后为false,则返回第一个值(不是被强制转换后的值),否则返回第二个值

||   找真,先看第一个表达式的值,如果第一个表达式不是布尔类型,强制转换成布尔类型,转换若后为true,则返回第一个值(不是被强制转换后的值),否则返回第二个值

!  非,   看表达式的值,如果表达式的值不是布尔类型,强制转换成布尔类型,若为true,则返回false,否则返回true。

 

短路运算的例子:

javascript代码:

<script>
        console.log("短路运算的&和|只比较第一个表达式,并由第一个表达式和运算符号决定返回哪个值");
        console.log("&&测试");
        console.log("&&找假");
        console.log(true&&true);
        console.log(true&&false);
        console.log(false&&true);
        console.log(false&&false);
        console.log(true&&"abs");//直接显示第二个表达式的值abs
        console.log(false&&"abs");//直接显示第一个表达式的值false
        console.log(""&&"abs");//什么都没显示,因为第一个表达式经Boolean强制转换后是false,所以显示第一个值
        console.log("abs"&&"qwe");//直接显示qwe

        console.log("||测试");
        console.log("||找真");
        console.log(true||true);
        console.log(true||false);
        console.log(false||true);
        console.log(false||false);
        console.log(true||"abs");//直接显示true
        console.log(false||"abs");//直接显示abs
        console.log(""||"abs");//显示abs
        console.log("abs"||"qwe");//显示abs

        console.log("!测试");
        console.log(!true);
        console.log(!false);
        console.log(!"abs");//字符串abs经boolean强制转换后是true,!true是false
        console.log(!"");//字符串经boolean强制转换后是false, !false是true
</script>

控制台截图:

                

 

posted @ 2016-07-29 20:07  灬安  阅读(8053)  评论(0编辑  收藏  举报