当前位置: 58彩票app下载 > 关于计算机 > 正文

JavaScript中的操作符,Parts阅读笔记

时间:2019-09-18 11:14来源:关于计算机
JavaScript的假值列表如下, JavaScript中,==与===操作符均可用于判断两个值是否相等;不同之处在于,如果进行判断的两个值类型不一致,===操作符会直接返回false,而==操作符则会在类型

JavaScript的假值列表如下,

JavaScript中,==与===操作符均可用于判断两个值是否相等;不同之处在于,如果进行判断的两个值类型不一致,===操作符会直接返回false,而==操作符则会在类型转换后再进行判断。详细的判断规则如下:

 

===操作符的判断规则

 类型

0

Number

NaN (非数字)

Number

'' (空字符串)

String

false

Boolean

null

Object

undefined

Undefined

以上的值作为判断条件,都将为假值,如:

1.如果两个值的类型不一致,返回false。
2.如果两个值的类型一致,值一致,返回true。NaN是一个特例,NaN===NaN返回false。
3.如果两个值均为object类型,那么与Java一样,除非两者引用一致(reference指向同一个对象地址),不然即使object中的内容完全一样,也认为这两个值不一致,相应的操作将返回false。比如,新建两个内容完全一样的数组,对它们进行===操作后返回结果为false — 虽然它们的内容完全一样,但还是属于两个不同的对象。
4.0===-0返回true。

复制代码 代码如下:

==操作符的判断规则

if(undefined) {
alert('undefined'); //这行代码不会执行
}
while(null)
{
alert('null'); //这行代码不会执行
}

==操作符会将值进行类型转换后再进行比较,其类型转换遵循以下原则:优先转换成number后进行比较,Date对象则优先转换成string后进行比较。具体判断规则如下:

虽然这些值全部都等同于假,但它们是不可互换的。
下面列出一些例子 :
undefined === null //false
undefined == null //true

1.如果两个值类型一致,执行===操作后返回。
2.null==undefined为true。
3.true将转换成1后进行比较,false将转换成0后进行比较。
4.如果其中一个值为对象,则将其转换成number后再进行比较,Date对象除外。
5.如果其中一个值为Date对象,则将其转换成string后再进行比较。

甚至
NaN === NaN //false
NaN == NaN //false
PS:NaN跟NaN无论用哪种运算都不相等,可以用IsNaN(NaN)来解决NaN的判断问题。

实验

==(!=)运算符会进行强制类型转换,而且转换规则相当诡异。下面是一些例子。

复制代码 代码如下:

复制代码 代码如下:

console.log("3" === 3);//false
console.log(NaN === NaN);//false
var a = {x:1, y:2};
var b = {x:1, y:2};
var c = a;
console.log(a === b);//false
console.log(a === c);//true
console.log(0 === -0);//true

'' == '0' // false
0 == '' // true
0 == '0' // true
false == 'false' // false
false == '0' // true
false == undefined // false
false == null // false
null == undefined // true
' trn ' == 0 // true

console.log("3" == 3);//true
console.log(null == undefined);//true
console.log(true == 1);//true
console.log(true == 9);//false

建议使用===(!===)运算符。

console.log([9] == 9);//true
console.log([9] == "9");//true

您可能感兴趣的文章:

  • 详解js中==与===的区别
  • javascript typeof id===''string''?document.getElementById(id):id解释
  • 浅谈JS中的!=、== 、!==、===的用法和区别
  • JavaScript中三个等号和两个等号的区别(== 和 ===)浅析
  • JavaScript里 ==与===区别详解
  • JavaScript知识点总结(五)之Javascript中两个等于号(==)和三个等于号(===)的区别
  • javascript中if和switch,==和===详解
  • JavaScript中的操作符==与===介绍
  • 浅析Javascript中“==”与“===”的区别
  • javascript中等于(==)与全等(===)的区别说明
  • JS中==与===操作符的比较
  • javaScript中"=="和"==="的区别详解

var d = new Date();
var s = d.toString();
var n = d.valueOf();
console.log(d == s);//true
console.log(d == n);//false

您可能感兴趣的文章:

  • 详解js中==与===的区别
  • javascript typeof id===''string''?document.getElementById(id):id解释
  • 浅谈JS中的!=、== 、!==、===的用法和区别
  • JavaScript中三个等号和两个等号的区别(== 和 ===)浅析
  • JavaScript里 ==与===区别详解
  • JavaScript知识点总结(五)之Javascript中两个等于号(==)和三个等于号(===)的区别
  • javascript中if和switch,==和===详解
  • 浅析Javascript中“==”与“===”的区别
  • javascript中等于(==)与全等(===)的区别说明
  • JavaScript.The.Good.Parts阅读笔记(一)假值与===运算符
  • JS中==与===操作符的比较
  • javaScript中"=="和"==="的区别详解

编辑:关于计算机 本文来源:JavaScript中的操作符,Parts阅读笔记

关键词: