在js中,为什么!0是true,!!0是false,!1是false,!!1是true,!-1是false,!!-1是true

JavaScript018

在js中,为什么!0是true,!!0是false,!1是false,!!1是true,!-1是false,!!-1是true,第1张

一、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。

参考资料:

百度百科--比较运算符

可以用正则表达式

<script type="text/javascript">

function validate(){

var reg = new RegExp("^[0-9]*$")

var obj = document.getElementById("name")

if(!reg.test(obj.value)){

alert("请输入数字!")//obj.value = 1

}

if(!/^[0-9]*$/.test(obj.value)){

alert("请输入数字!")//obj.value = 1

}

}

</script>

我复制的、

验证非零的正整数:^\+?[1-9][0-9]*$

http://lives.iteye.com/blog/1397939

<!DOCTYPE html>

<html>

<head>

<meta charset="UTF-8">

<title></title>

</head>

<body>

<input type="button" id="" value="数字验证" onclick="test1()"/>

<br />

<input type="text" id="numb1" value="" />

<script type="text/javascript">

function test1(){

var numb1=document.getElementById("numb1").value

var reg1=/^(0|[1-9][0-9]*)$///以零开头

var reg2=/^\d{1,6}$///长度为1至6

if(reg1.test(numb1)){

if(reg2.test(numb1)){

alert("符合")

    }

}

}

</script>

</body>

</html>