为什么在javascript里 o取反后是false ??

JavaScript012

为什么在javascript里 o取反后是false ??,第1张

js规定非零非空即真。

undefined、null、0、NaN、""

除了上诉几个值在转换成布尔值会转成false外,其他任何对象任何值转成布尔值都是true

因为取反就是把对象转换成bool值的,所以会先把num转成布尔值,然后再取反得到true。

然后在弹出。。。

------------------------------------

不对啊,按这逻辑应该弹出true的。

首先了解JavaScript中字符串和数组的区别:

①字符串是不可变的,数组是可变的。字符串不可变是指字符串的成员函数不会改变其原始值,而是创建并返回一个新的字符串。而数组的成员函数都是在其原始值上进行操作。

②数组有一个字符串没有的可变更成员函数reserve()。

方法一:先将字符串转化为数组,待处理完后再将结果转化回字符串:

split()方法将一个字符串拆成字符并返回一个数组

reverse()方法使数组反转

join()方法将数组中的所有元素边接成一个字符串

var a="foo"

var b=a.split("")//转化为字符串数组

            .reverse()//进行反转

            .join("")//数组中的字符拼接回字符串

方法二:把字符串中的字符倒序存入数组,再将数组转化为字符串:

var newString = []

for(var i = a.length-1,j = 0i >= 0i --,j ++){

    newString[j] = a[i]

}

newString.join()

一、js中的数字0就是false,非0为true,!表示取反。所以:!0--false取反--true;!!0--false双重取反--false;!1--true取反--false;!!1--双重取反--true;!-1--true取反--false!!-1--true双重取反--true。二、==和===:==:先检查两个操作数数据类型,如果相同,则进行===比较,如果不同,则愿意为你进行一次类型转换,转换成相同类型后再进行比较;===:如果类型不同,直接就是false。具体比较过程:1、双等号==: (1)如果两个值类型相同,再进行三个等号(===)的比较。(2)如果两个值类型不同,也有可能相等,需根据以下规则进行类型转换在比较:如果一个是null,一个是undefined,那么相等。如果一个是字符串,一个是数值,把字符串转换成数值之后再进行比较。2、 三等号===:(1)如果类型不同,就一定不相等。(2)如果两个都是数值,并且是同一个值,那么相等;如果其中至少一个是NaN,那么不相等。(判断一个值是否是NaN,只能使用isNaN()来判断)。(3)如果两个都是字符串,每个位置的字符都一样,那么相等,否则不相等。如果两个值都是true,或是false,那么相等。如果两个值都引用同一个对象或是函数,那么相等,否则不相等。如果两个值都是null,或是undefined,那么相等。扩展资料:在js做比较的时候,有这样的三条规则:1、如果比较的两者中有bool,会把bool先转换为对应的number,即0和1。2、如果比较的双方中有一方为number一方为string,会把string转换为数字。3、把string直接转换为bool的时候,空字符串‘'转换为false,除此外的一字符串转换为true。参考资料:百度百科--比较运算符