js 操作符汇总


Posted in Javascript onNovember 08, 2014

逻辑或(||)

var result = true || false;
与逻辑与操作相似,如果有一个操作数不是布尔值,逻辑或也不一定返回布尔值;此时,它遵循下列规则:
□ 如果第一个操作数是对象,则返回第一个操作数。

□ 如果第一个操作数求值为false,则返回第二个操作数。

□ 如果两个操作数都是对象,则返回第一个操作数。

□ 如果两个操作数都是null,返回null

□ 如果两都为undefined,返undefined。

□ 如果两都为NaN,返NaN

“===”与“==”的区别

相等操作符(==)

相等操作符会对操作值进行隐式转换后进行比较:

如果一个操作值为布尔值,则在比较之前先将其转换为数值
如果一个操作值为字符串,另一个操作值为数值,则通过Number()函数将字符串转换为数值
如果一个操作值是对象,另一个不是,则调用对象的valueOf()方法,得到的结果按照前面的规则进行比较
null与undefined是相等的
如果一个操作值为NaN,则相等比较返回false
如果两个操作值都是对象,则比较它们是不是指向同一个对象。如果两个操作数都指向同一个对象,则相等操作符返回true,否则,返回false
下面分别说明:
先说 ===,这个比较简单。下面的规则用来判断两个值是否===相等:
1、如果类型不同,就[不相等]
2、如果两个都是数值,并且是同一个值,那么[相等];(!例外)的是,如果其中至少一个是NaN,那么[不相等]。(判断一个值是否是NaN,只能用isNaN()来判断)
3、如果两个都是字符串,每个位置的字符都一样,那么[相等];否则[不相等]。
4、如果两个值都是true,或者都是false,那么[相等]。
5、如果两个值都引用同一个对象或函数,那么[相等];否则[不相等]。
6、如果两个值都是null,或者都是undefined,那么[相等]。

再说 ==,根据以下规则:
1、如果两个值类型相同,进行 === 比较。
2、如果两个值类型不同,他们可能相等。根据下面规则进行类型转换再比较:
a、如果一个是null、一个是undefined,那么[相等]。
b、如果一个是字符串,一个是数值,把字符串转换成数值再进行比较。
c、如果任一值是 true,把它转换成 1 再比较;如果任一值是 false,把它转换成 0 再比较。
d、如果一个是对象,另一个是数值或字符串,把对象转换成基础类型的值再比较。对象转换成基础类型,利用它的toString或者valueOf方法。js核心内置类,会尝试valueOf先于toString;例外的是Date,Date利用的是toString转换。非js核心的对象,令说(比较麻烦,我也不大懂)
e、任何其他组合,都[不相等]。

表达式 值 表达式 值
null==undefined true true==1 true
"NaN" ==NaN false $null==0 false
false==0 true NaN!=NaN true
简而言之就是“==”只要求值相等。“===”要求值和类型都相等。

资料来源于javascript高级程序设计,整理下,后续更新js 操作符汇总

Javascript 相关文章推荐
js下用gb2312编码解码实现方法
Dec 31 Javascript
js ondocumentready onmouseover onclick onmouseout 样式
Jul 22 Javascript
js 定时器setTimeout无法调用局部变量的解决办法
Nov 28 Javascript
jQuery避免$符和其他JS库冲突的方法对比
Feb 20 Javascript
jQuery绑定事件on()与弹窗的简要概述
Apr 27 Javascript
jQuery实现日期联动效果实例
Jul 26 Javascript
vue实现tab切换外加样式切换方法
Mar 16 Javascript
浅析前端路由简介以及vue-router实现原理
Jun 01 Javascript
angular中如何绑定iframe中src的方法
Feb 01 Javascript
微信小程序自定义多列选择器使用详解
Jun 21 Javascript
世界上最短的数字判断js代码
Sep 09 Javascript
angular *Ngif else用法详解
Dec 15 Javascript
jquery的总体架构分析及实现示例详解
Nov 08 #Javascript
jquery常用方法及使用示例汇总
Nov 08 #Javascript
JQuery遍历json数组的3种方法
Nov 08 #Javascript
JQuery中使用.each()遍历元素学习笔记
Nov 08 #Javascript
jQuery遍历之next()、nextAll()方法使用实例
Nov 08 #Javascript
jQuery遍历对象、数组、集合实例
Nov 08 #Javascript
JavaScript中具名函数的多种调用方式总结
Nov 08 #Javascript
You might like
windows下PHP APACHE MYSQ完整配置
2007/01/02 PHP
使用Limit参数优化MySQL查询的方法
2008/11/12 PHP
PHP UTF8中文字符截断函数代码
2012/09/11 PHP
PHP验证码生成原理和实现
2016/01/24 PHP
Laravel开启跨域请求的方法
2019/10/13 PHP
javascript 火狐(firefox)不显示本地图片问题解决
2008/07/05 Javascript
iframe自适应宽度、高度 ie6 7 8,firefox 3.86下测试通过
2010/07/29 Javascript
jQuery fadeTo方法调整图片的透明度使用介绍
2013/05/06 Javascript
js获取某月的最后一天日期的简单实例
2013/06/22 Javascript
js判断浏览器类型的方法
2013/08/07 Javascript
Egret引擎开发指南之视觉编程
2014/09/03 Javascript
JS常用函数使用指南
2014/11/23 Javascript
jQuery中element选择器用法实例
2014/12/29 Javascript
JavaScript中的small()方法使用详解
2015/06/08 Javascript
javascript获取wx.config内部字段解决微信分享
2016/03/09 Javascript
详解Angular中$cacheFactory缓存的使用
2016/08/19 Javascript
深入理解vue中的$set
2017/06/01 Javascript
Element输入框带历史查询记录的实现示例
2019/01/15 Javascript
DatePickerDialog 自定义样式及使用全解
2019/07/09 Javascript
原生JS实现京东查看商品点击放大
2020/12/21 Javascript
[03:00]2014DOTA2国际邀请赛 Titan淘汰潸然泪下Ohaiyo专访
2014/07/15 DOTA
Python使用MONGODB入门实例
2015/05/11 Python
python集合用法实例分析
2015/05/30 Python
详解Python函数可变参数定义及其参数传递方式
2017/08/02 Python
django 将model转换为字典的方法示例
2018/10/16 Python
python批量识别图片指定区域文字内容
2019/04/30 Python
python pip源配置,pip配置文件存放位置的方法
2019/07/12 Python
如何快速一次性卸载所有python包(第三方库)呢
2020/10/20 Python
python实现MySQL指定表增量同步数据到clickhouse的脚本
2021/02/26 Python
AVI-8手表美国官方商店:AVI-8 USA
2019/04/10 全球购物
奶茶专卖店创业计划书
2014/01/18 职场文书
揭牌仪式策划方案
2014/05/28 职场文书
以幸福为主题的活动方案
2014/08/22 职场文书
趣味运动会广播稿
2014/09/13 职场文书
初中生旷课检讨书范文
2014/10/06 职场文书
一篇文章告诉你如何实现Vue前端分页和后端分页
2022/02/18 Vue.js