js中bool值的转换及“&&”、“||”、 “!!”详解


Posted in Javascript onDecember 21, 2017

前言

首先需要知道的是,js中有6个值为false,分别是: 0, '', null, undefined, NaN 和 false, 其他(包括{}, [], Infinity)为true.

可以使用Boolean()函数或是两次取非就能获得对象的布尔值,例如Boolean(undefined)和!!undefined同样能取得布尔值false,

对于0, '', null, undefined, NaN,{}, [], Infinity求布尔值,分别是false false false false false true true true.

因此我们知道的一点是:对象的布尔值是true,即使是对象{}。

bool值转换

数据类型 bool值转化
undefined undefined 转化为 false
Object null 转化为false,其他为 true
Boolean false 转化为 false,true 转化为 true
Number 0,NaN 转化为false,其他为 true
String "" 转化为 false,其他为 true

"&&"

javascript中“&&”运算符运算法则如下:

如果&&左侧表达式的值为真值,则返回右侧表达式的值;否则返回左侧表达式的值。多个&&表达式一起运算时,返回第一个表达式运算为false的值,如果所有表达式运算结果都为true,则返回最右侧一个表达式运算的值。

const aa = {'name': 'xx'};
const bb = aa && aa.age; // bb输出为undefined;
let cc;
const dd = cc && cc.name ? cc.name : undefined; // dd输出为undefined
const dd = cc && cc.name; // dd输出为undefined;

上面两句代码的执行结果是一样的,之前写代码的时候一直用上面的方式,但是发现有些单测覆盖不到,导致单测分支覆盖率很低,换下面的方式就可以很好的解决这个问题,这两句的效果是一样的。

"||"

javascript中"||"运算符的运算法则如下:

如果"||"左侧表达式的值为真值,则返回左侧表达式的值;否则返回右侧表达式的值。多个"||"表达式一起运算时,返回第一个表达式运算结果为true的值,如果所有表达式运算结果都为false,否则返回最右侧的表达式的值。

const aa = false || 'xx'; // aa输出为'xx'

"!!"

"!!"将表达式进行强制转化为bool值的运算,运算结果为true或者false。

const aa = 'xx';
const bb = !!aa; // bb输出为true
const cc = !!(NaN || undefined || null || 0 || '' ); // cc为false;

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
Js数组排序函数sort()介绍
Jun 08 Javascript
PhantomJS快速入门教程(服务器端的 JavaScript API 的 WebKit)
Aug 06 Javascript
javascript合并表格单元格实例代码
Jan 03 Javascript
详解AngularJs中$sce与$sceDelegate上下文转义服务
Sep 21 Javascript
Angular.js实现多个checkbox只能选择一个的方法示例
Feb 24 Javascript
源码分析Vue.js的监听实现教程
Apr 23 Javascript
老生常谈js中的MVC
Jul 25 Javascript
EasyUI创建人员树的实例代码
Sep 15 Javascript
JavaScript实现删除数组重复元素的5种常用高效算法总结
Jan 18 Javascript
基于vue-cli 打包时抽离项目相关配置文件详解
Mar 07 Javascript
新版小程序登录授权的方法
Dec 12 Javascript
基于vue 实现表单中password输入的显示与隐藏功能
Jul 19 Javascript
利用node实现一个批量重命名文件的函数
Dec 21 #Javascript
详解webpack3编译兼容IE8的正确姿势
Dec 21 #Javascript
利用vue开发一个所谓的数独方法实例
Dec 21 #Javascript
开发Vue树形组件的示例代码
Dec 21 #Javascript
详解使用vuex进行菜单管理
Dec 21 #Javascript
Angular5.1新功能分享
Dec 21 #Javascript
vue2中的keep-alive使用总结及注意事项
Dec 21 #Javascript
You might like
PHP 数据结构 算法描述 冒泡排序 bubble sort
2011/07/10 PHP
用Php编写注册后Email激活验证的实例代码
2013/03/11 PHP
FireFox JavaScript全局Event对象
2009/06/14 Javascript
JavaScript 异步调用框架 (Part 2 - 用例设计)
2009/08/03 Javascript
关于JavaScript的with 语句的使用方法
2011/05/09 Javascript
深入理解JavaScript系列(8) S.O.L.I.D五大原则之里氏替换原则LSP
2012/01/15 Javascript
jquery得到font-size属性值实现代码
2013/09/30 Javascript
jquery控制display属性为none或block
2014/03/31 Javascript
Jquery通过JSON字符串创建JSON对象
2014/08/24 Javascript
简单谈谈jQuery(function(){})与(function(){})(jQuery)
2014/12/19 Javascript
JS实现动态移动层及拖动浮层关闭的方法
2015/04/30 Javascript
浅析Node.js:DNS模块的使用
2016/11/23 Javascript
jQuery加密密码到cookie的实现代码
2017/04/18 jQuery
基于vue实现swipe轮播组件实例代码
2017/05/24 Javascript
微信小程序 地图map实例详解
2017/06/07 Javascript
基于JavaScript实现飘落星星特效
2017/08/10 Javascript
详解node字体压缩插件font-spider的用法
2018/09/28 Javascript
使用iView Upload 组件实现手动上传图片的示例代码
2018/10/01 Javascript
vue项目中使用Svg的方法
2018/10/24 Javascript
js实现百度登录窗口拖拽效果
2020/03/19 Javascript
在服务器端实现无间断部署Python应用的教程
2015/04/16 Python
Python中的日期时间处理详解
2016/11/17 Python
Python实现的购物车功能示例
2018/02/11 Python
Python实现一个服务器监听多个客户端请求
2018/04/12 Python
python编写暴力破解zip文档程序的实例讲解
2018/04/24 Python
python实现随机漫步算法
2018/08/27 Python
Linux下安装python3.6和第三方库的教程详解
2018/11/09 Python
python 移动图片到另外一个文件夹的实例
2019/01/10 Python
python实现扫描ip地址的小程序
2019/04/16 Python
10分钟教你用python动画演示深度优先算法搜寻逃出迷宫的路径
2019/08/12 Python
WSDL的操作类型主要有几种
2013/07/19 面试题
高校自主招生自荐信
2013/12/09 职场文书
经典的毕业生自荐信范文
2014/04/14 职场文书
感恩节活动策划方案
2014/05/16 职场文书
律政俏佳人观后感
2015/06/09 职场文书
淮海战役观后感
2015/06/11 职场文书