十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章主要介绍javascript中的恒等运算符是哪个,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
创新互联公司坚信:善待客户,将会成为终身客户。我们能坚持多年,是因为我们一直可值得信赖。我们从不忽悠初访客户,我们用心做好本职工作,不忘初心,方得始终。十载网站建设经验创新互联公司是成都老牌网站营销服务商,为您提供成都网站设计、网站制作、外贸营销网站建设、网站设计、H5建站、网站制作、高端网站设计、成都微信小程序服务,给众多知名企业提供过好品质的建站服务。
在javascript中,恒等运算符是“===”,用于比较等式两边的操作数是否相等。“===”在比较运算时,不仅会比较两个操作数的值是否相等,还会检测它们的类型是否相同;只要值相等,类型相同,就会返回true。
本教程操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。
在javascript中,恒等运算符是“===”,用于比较等式两边的操作数是否相等。
“===”运算符在比较运算时,不仅会比较两个操作数的值是否相等,还会检测它们的类型是否相同。
在恒等运算中,应注意以下几个问题:
如果两个操作数都是简单的值,则只要值相等,类型相同,就全等。
如果一个操作数是简单的值,另一个操作数是复合型对象,则不全等。
如果两个操作数都是复合型对象,则比较引用地址是否相同。
(1)如果类型不同,就一定不相等
(2)如果两个都是数值,并且是同一个值,那么相等;如果其中至少一个是NaN,那么不相等。(判断一个值是否是NaN,只能使用isNaN( ) 来判断)
(3)如果两个都是字符串,每个位置的字符都一样,那么相等,否则不相等。
(4)如果两个值都是true,或是false,那么相等
(5)如果两个值都引用同一个对象或是函数,那么相等,否则不相等
(6)如果两个值都是null,或是undefined,那么相等
示例1
下面是特殊操作数的全等比较。
console.log(null === undefined); //返回false console.log(0 === "0"); //返回false console.log(0 === false); //返回false
示例2
下面是两个对象的比较,由于它们都引用了相同的地址,所以返回 true。
var a = {}; var b = a; console.log(a === b); //返回true
下面两个对象虽然结构相同,但是地址不同,所以不全等。
var a = {}; var b = {}; console.log(a === b); //返回false
示例3
对于复合型对象,主要比较引用的地址,不比较对象的值。
var a = new String("abcd); //定义字符串“abcd”对象 var b = new String("abcd); //定义字符串“abcd”对象 console.log(a === b); //返回false console.log(a == b); //返回false
在上面示例中,两个对象的值相等,但是引用地址不同,所以它们既不想等,也不全等。因此,对于复合型对象来说,相等==和全等===运算的结果是相同的。
示例4
对于简单的值,只要类型相同、值相等,它们就是全等,不考虑表达式运算的过程变化,也不用考虑变量的引用地址。
var a = "1" + 1; var b = "11"; console.log(a ===b); //返回true
示例5
表达式(a>b || a==b)与表达式(a>=b)并不完全相等。
var a = 1; var b = 2; console.log((a > b || a == b) == (a >= b)); //返回true,此时似乎相等
如果为变量 a 和 b 分别赋值 null 和 undefined,则返回值 false,说明这两个表达式并非完全等价。
var a = null; var b = undefined; console.log((a > b || a == b) == (a >= b)); //返回false,表达式的值并非相等
因为 null == undefined 等于 true,所以表达式(a > b || a == b)的返回值为 true,但是表达式 null >= undefined 的返回值为 false。
以上是“javascript中的恒等运算符是哪个”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!