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 相关文章推荐
一个很简单的jquery+xml+ajax的无刷新树结构(无css,后台是c#)
Jun 02 Javascript
javascript forEach通用循环遍历方法
Oct 11 Javascript
bootstrap data与jquery .data
Jul 07 Javascript
解决node-webkit 不支持html5播放mp4视频的方法
Mar 11 Javascript
TypeScript 学习笔记之基本类型
Jun 19 Javascript
js验证身份证号有效性并提示对应信息
Oct 19 Javascript
快速获取/设置iframe内对象元素的几种js实现方法
May 20 Javascript
jQuery事件绑定用法详解
Sep 08 Javascript
jquery easyui如何实现格式化列
Jul 30 jQuery
vue router动态路由下让每个子路由都是独立组件的解决方案
Apr 24 Javascript
vue.js实现插入数值与表达式的方法分析
Jul 06 Javascript
浅析微信扫码登录原理(小结)
Oct 29 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 CURL获取邮箱地址的详解
2013/06/03 PHP
php cURL和Rolling cURL并发方式比较
2013/10/30 PHP
ThinkPHP实现事务回滚示例代码
2014/06/23 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(八)
2014/06/23 PHP
php合并数组中相同元素的方法
2014/11/13 PHP
php实现映射操作实例详解
2019/10/02 PHP
PHP For循环字母A-Z当超过26个字母时输出AA,AB,AC
2020/02/16 PHP
Tab页界面,用jQuery及Ajax技术实现
2009/09/21 Javascript
纯js实现背景图片切换效果代码
2010/11/14 Javascript
读jQuery之十四 (触发事件核心方法)
2011/08/23 Javascript
Jquery实现弹出层分享微博插件具备动画效果
2013/04/03 Javascript
使用js 设置url参数
2013/07/08 Javascript
JavaScript获取FCK编辑器信息的具体方法
2013/07/12 Javascript
在百度知道团队中快速审批新成员的js脚本
2014/02/02 Javascript
jQuery中map()方法用法实例
2015/01/06 Javascript
JavaScript运算符小结
2015/06/03 Javascript
jQuery实现漂亮实用的商品图片tips提示框效果(无图片箭头+阴影)
2016/04/16 Javascript
jQuery完成表单验证的实例代码(纯代码)
2017/09/30 jQuery
JS和JQuery实现雪花飘落效果
2017/11/30 jQuery
Vue 页面状态保持页面间数据传输的一种方法(推荐)
2018/11/01 Javascript
[49:07]VGJ.T vs Optic Supermajor小组赛D组 BO3 第二场 6.3
2018/06/04 DOTA
Django 迁移、操作数据库的方法
2019/08/02 Python
浅谈对pytroch中torch.autograd.backward的思考
2019/12/27 Python
浅谈Selenium 控制浏览器的常用方法
2020/12/04 Python
CSS3实现全景图特效示例代码
2018/03/26 HTML / CSS
html5 外链式实现加减乘除的代码
2019/09/04 HTML / CSS
Kathmandu美国网站:新西兰户外运动品牌
2019/03/23 全球购物
中专药剂专业应届毕的自我评价
2013/12/27 职场文书
2014年维修工作总结
2014/11/22 职场文书
利用python做表格数据处理
2021/04/13 Python
Anaconda安装pytorch及配置PyCharm 2021环境
2021/06/04 Python
Html5获取用户当前位置的几种方式
2022/01/18 HTML / CSS
Flutter集成高德地图并添加自定义Maker的实践
2022/04/07 Java/Android
virtualenv隔离Python环境的问题解析
2022/06/21 Python
服务器nginx权限被拒绝解决案例
2022/09/23 Servers