JS之相等操作符详解
1.相等 == 和不相等 !=
先转换操作数再比较相等性
在转换不同的数据类型时,相等和不相等遵循以下规则:
1.1 如果有一个操作数是布尔值,则在比较相等性前先将其转换为数值---false转换为0,true转换为1;
1.2 如果一个操作数是字符串,另一个操作数是数值,则在比较相等性前将字符串转换为数值
1.3 如果一个操作数是对象昂,另一个不是,则调用对象的valueOf()方法,用得到的基本类型值按照前面的规则比较
1.4 null和undefined是相等的
1.5 在比较相等性之前,不能将null和undefined转换为其他任何值
1.6 如果有一个操作符是NaN,则相等操作符返回false,不相等操作符返回true;即使两个操作数都是NaN,也一样
1.7 如果两个操作数都是对象,则比较它们是否指向同一个对象
表达式 | 值 |
null == undefined | true |
"NaN" == NaN | false |
5 == NaN | false |
NaN == NaN | false |
NaN != NaN | true |
5 =="5" | true |
false == 0 | true |
true == 1 | true |
true == 2 | flase |
undefined == 0 | false |
null == 0 | false |
2.全等=== 和全不等 !==
两个操作数在未经转换的情况下相等返回true,不相等返回false;
undefined == null;//true
undefined === null;// false
以上这篇JS之相等操作符详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。
相关推荐
-
Javascript基础教程之比较操作符
和其他语言一样,JavaScript也有条件语句对流程上进行判断.包括各种操作符合逻辑语句 比较操作符 常用的比较操作符有 等于 == , 不等于!= , 大于 >, 小于 <,大于等于 >= ,小于等于 <= 复制代码 代码如下: document.write("Study" == "study");//false document.write("Study" < "study&quo
-
javascript操作符"!~"详解
快过年放假了,也终于闲下来了.每天游览于各种技术文章中,这种状态好极了. 下午看篇关于js的文章,其中有如下这么一段引起了我的注意. 复制代码 代码如下: (function () { var names = []; return function (name) { addName(name); } function addName(name) { if (!~names.indexOf(name))//如果存在则不添加
-
JavaScript中的各种操作符使用总结
一元操作符 只能操作一个值的操作符叫一元操作符. 一元操作符是ECMAScript中最简单的操作符. 1.递增和递减操作符 递增递减操作符直接借鉴C,而且各有两个版本:前置型和后置型.顾明思义,前置型应该让位于要操作的变量之前,而后置型应该位于要操作的变量之后. 前置型: var num1 = 1; var num2 = 2; var num3 = ++num1 + num2;//4 后置型: var num1 = 1; var num2 = 2; var num3 = num1++ + num
-
js中的内部属性与delete操作符介绍
在讲解Configurable之前,我们首先来看一道面试题: a = 1; console.log( window.a ); // 1 console.log( delete window.a ); // true console.log( window.a ); // undefined var b = 2; console.log( window.b ); // 2 console.log( delete window.b ); // false console.log( window.b
-
浅谈javascript中new操作符的原理
javascript中的new是一个语法糖,对于学过c++,java 和c#等面向对象语言的人来说,以为js里面是有类和对象的区别的,实现上js并没有类,一切皆对象,比java还来的彻底 new的过程实际上是创建一个新对象,把新象的原型设置为构造器函数的原型,在使用new的过程中,一共有3个对象参与了协作,构造器函数是第一个对象,原型对象是二个,新生成了一个空对象是第三个对象,最终返回的是一个空对象,但这个空对象不是真空的,而是已经含有原型的引用(__proto__) 步骤如下: (1) 创建一
-
javascript中typeof操作符和constucor属性检测
*#type.js 复制代码 代码如下: function Person(name, age) { this.name = name; this.age = age; } var d = {an: 'object'}; var a = ['apple', 'banana']; var f = function() {}; var s = 'David'; var n = 33; var b = true; var o = new Object(); var person = new Pers
-
全面解析JavaScript中“&&”和“||”操作符(总结篇)
1.||(逻辑或), 从字面上来说,只有前后都是false的时候才返回false,否则返回true. alert(true||false); // true alert(false||true); // true alert(true||true); // true alert(false||false); // false 这个傻子都知道~~ 但是,从深层意义上来说的话,却有另一番天地,试下面代码 alert(0||1);//1 显然,我们知道,前面0意味着false,而后面1意味着true,
-
JavaScript中诡异的delete操作符
delete这个操作符呢,在javascript中不是很常用,但是他的特性的确很诡异. 1,删除对象的属性,代码: 复制代码 代码如下: var o = { a: 1, b: 2 }; delete o.a; alert(o.a); //undefined 那么到底delete删除的是对象的属性还是对象的属性值呢,我开始觉得删除的应该是值,因为结果是undefined,而没有报错.但是事实上,我的看法是错误的,举例说明: 复制代码 代码如下: var o = {}; var
-
总结JavaScript中布尔操作符||与&&的使用技巧
你是否看到过这样的代码:a=a||""; 可能javascript初学者会对此感到茫然.今天就跟大家分享一下我的一些心得. 其实: a=a||"defaultValue"; a=a||"defaultValue"; 与: if(!a){ a="defaultValue"; } if(!a){ a="defaultValue"; } 和: if(a==null||a==""||a==und
-
JavaScript中的操作符类型转换示例总结
首先,我们先来做一些题目吧!为了统一,我不混着来写这些题目,面试题目中,经常将这些题目混起来,这样对你的迷惑度会更大,为了更方便演示,我在这里分模块写了一些题目,大家可以看下! 操作符字符串的隐性转换 乘法 console.dir("-------以下乘法---------"); console.dir(5*"5"); console.dir(5*"a"); console.dir(5*NaN); console.dir(5*null); co
随机推荐
- 详解VirtualBox中与主机共享文件夹的方法(图文)
- SqlServer2005 自动备份并存储另一电脑上的存储过程函数
- iOS 懒加载的使用实例代码
- 兼容iOS 10 升级xcode8出现的问题及一些适配问题的解决方案
- PHP中的排序函数sort、asort、rsort、krsort、ksort区别分析
- 使用PHP实现阻止用户上传成人照片或者裸照
- 利用ASP发送和接收XML数据的处理方法
- C# httpwebrequest访问HTTPS错误处理方法
- javascript实现状态栏文字首尾相接循环滚动的方法
- 让人不得不佩服的CSS效果
- EasyUI Combobox设置默认值 获取text的方法
- Javascript日期对象的dateAdd与dateDiff方法
- python 获取网页编码方式实现代码
- jQuery插件Elastislide实现响应式的焦点图无缝滚动切换特效
- 使用javascript获取页面名称
- Add a Picture to a Microsoft Word Document
- javascript 表格左右收缩
- android创建手势识别示例代码
- 实现 win2003 下 mysql 数据库每天自动备份
- 详解vue.js数据传递以及数据分发slot