JavaScript 布尔操作符解析  && || !


Posted in Javascript onAugust 10, 2012

1、逻辑非

逻辑非用!表示,可以应用与ECMAScript的任何类型的值,逻辑非操作返回的是一个布尔值(true/false)。该操作符首先会将它的操作数转换为一个布尔值,然后再对其求反。

下面说明下Boolean()转型函数的一组规则。

数据类型 转换为true的值 转换为false的值
Boolean true false
String 任何非空字符串 ""(空字符串)
Number  任何非零数字值(包括无穷大) 0和NaN
Object 任何对象 null
Undefined  无 undefined

Boolean()转型函数的简便表示方法。-----------!!

2、逻辑与

逻辑与操作符由两个和号(&&)表示,有两个操作数。

逻辑与操作可以应用于任何类型的操作数,而不仅仅是布尔值。在有一个操作数不是布尔值的情况下,逻辑与操作就不一定返回布尔值;此时,它遵循一下规则:

1. 如果第一个操作数是对象,则返回第二个操作数;
2. 如果第二个操作数是对象,则只有在第一个操作数的求值结果为true的情况下才会返回该对象;
3. 如果两个操作符都是对象,则返回第二个操作数; 遵循第一规则。
4. 如果有一个操作是null,则返回null;
5. 如果有一个操作符是NaN,则返回NaN;
6. 如果有一个操作符是undefined,则返回undefined。

逻辑与操作属于短路操作,即如果第一操作数能够决定结果,那么就不会再对第二个操作数求值。(可以理解为内部的两个return操作)。因此当4、5、6规则冲突时,遵循短路操作原则。

var nul = null; 
var na = NaN; 
var test; 
test = na&&nul; 
document.write(test); //NaN
var nul = null; 
var na = NaN; 
var test; 
test = nul&&na; 
document.write(test); //null

因此,我们来总结一下。&&操作主要遵循几大原则:

1.短路操作原则;
2.求值过程中会被转型生成副本,但是返回值是原来值;

// 伪代码 
function &&(param1,param2){ 
bparam1 = Boolean(param1); 
if (!bparam1) return param1; 
bparam2 = Boolean(param2); 
return param2; 
} 
// 参数是一个对象时返回引用的指针值,函数同

3、逻辑或

逻辑或符号由两个竖线符号(||)表示。
逻辑或符号同样是短路操作符。其实现过程可以参照逻辑与的伪代码。这里就不再列出一些规则了。
逻辑或常常用来做参数的缺省处理,比如 evt = evt || window.event;

Javascript 相关文章推荐
Google Suggest ;-) 基于js的动态下拉菜单
Oct 11 Javascript
document.getElementById为空或不是对象的解决方法
Jan 24 Javascript
jQuery 获取对象 定位子对象
May 31 Javascript
JavaScript子类用Object.getPrototypeOf去调用父类方法解析
Dec 05 Javascript
跟我学Node.js(四)---Node.js的模块载入方式与机制
Jun 04 Javascript
jQuery的Read()方法代替原生JS详解
Nov 08 Javascript
jQuery Validate插件自定义验证规则的方法
Dec 27 Javascript
微信小程序 图片上传实例详解
May 05 Javascript
JavaScript代码判断输入的字符串是否含有特殊字符和表情代码实例
Aug 17 Javascript
微信小程序用户自定义模版用法实例分析
Nov 28 Javascript
angularJs使用ng-repeat遍历后选中某一个的方法
Sep 30 Javascript
详解javascript replace高级用法
Feb 17 Javascript
JS多物体 任意值 链式 缓冲运动
Aug 10 #Javascript
JavaScript之引用类型介绍
Aug 10 #Javascript
jquery下checked取值问题的解决方法
Aug 09 #Javascript
js分解url参数(面向对象-极简主义法应用)
Aug 09 #Javascript
深入理解javascript学习笔记(一) 编写高质量代码
Aug 09 #Javascript
JS数学函数Exp使用说明
Aug 09 #Javascript
基于jQuery实现左右div自适应高度完全相同的代码
Aug 09 #Javascript
You might like
PHP 木马攻击防御技巧
2009/06/13 PHP
PHP实现二维数组按某列进行排序的方法
2016/11/18 PHP
PHP实现时间比较和时间差计算的方法示例
2017/07/24 PHP
Microsoft Ajax Minifier 压缩javascript的方法
2010/03/05 Javascript
写了10年的Javascript也未必全了解的连续赋值运算
2011/03/25 Javascript
javascript的document.referrer浏览器支持、失效情况总结
2014/07/18 Javascript
jQuery对象的selector属性用法实例
2014/12/27 Javascript
jQuery中wrapAll()方法用法实例
2015/01/16 Javascript
js运动动画的八个知识点
2015/03/12 Javascript
JS类的定义与使用方法深入探索
2016/11/26 Javascript
js模拟微博发布消息
2017/02/23 Javascript
Mui使用jquery并且使用点击跳转新窗口的实例
2017/08/19 jQuery
解决iView中时间控件选择的时间总是少一天的问题
2018/03/15 Javascript
vue 的点击事件获取当前点击的元素方法
2018/09/15 Javascript
express 项目分层实践详解
2018/12/10 Javascript
vue项目前端微信JSAPI与外部H5支付相关实现过程及常见问题
2020/04/14 Javascript
[01:10:58]KG vs TNC 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
python判断字符串是否纯数字的方法
2014/11/19 Python
Python上传package到Pypi(代码简单)
2016/02/06 Python
python出现"IndentationError: unexpected indent"错误解决办法
2017/10/15 Python
python3调用R的示例代码
2018/02/23 Python
解决Django的request.POST获取不到内容的问题
2018/05/28 Python
django实现用户注册实例讲解
2019/10/30 Python
Python之——生成动态路由轨迹图的实例
2019/11/22 Python
python3中pip3安装出错,找不到SSL的解决方式
2019/12/12 Python
python通过文本在一个图中画多条线的实例
2020/02/21 Python
mac在matplotlib中显示中文的操作方法
2020/03/06 Python
Python+redis通过限流保护高并发系统
2020/04/15 Python
PIL.Image.open和cv2.imread的比较与相互转换的方法
2020/06/03 Python
GetYourGuide台湾:预订旅游活动、景点和旅游项目
2019/06/10 全球购物
俄罗斯第一家多品牌在线奢侈品精品店:Aizel.ru
2020/09/06 全球购物
Servlet如何得到客户端机器的信息
2014/10/17 面试题
学习十八大精神心得体会
2013/12/31 职场文书
小组合作学习反思
2014/02/18 职场文书
关于保护环境的标语
2014/06/09 职场文书
宣传普通话标语
2014/06/27 职场文书