JS在if中的强制类型转换方式


Posted in Javascript onJuly 15, 2018

众所周知,JS在很多情况下会进行强制类型转换,其中,最常见两种是:

1.使用非严格相等进行比较,对==左边的值进行类型转换

2.在if判断时,括号内的值进行类型转换,转化为布尔值

今天,我就来聊一聊JS在if中的强制类型转换。

其实,如果详细要讨论哪些值在if中强制转换为true,哪些值在if中强制转换为false,这很困难,因为,情况太多了。但是,我们可以轻松记住强制类型转换结果,为什么?因为,大多数情况下,都是转换为true,只有四种情况会转换为false。此时,我们只需要记住转换为false的那四种情况就可以了。

强制转换为false的四种情况

在if中进行强制转换为false的情况只有四种,分别是:

1.数字0

2.NaN

3.空字符串

4.null或undefined

很多人会问,为什么null和undefined会在一起?因为,在非严格相等的情况下,null和undefined是相等的。

null == undefined    // true
// 两种写法相等
a == null
a === null || a === undefined

如何判断引用数组和对象是否为空

很多时候,我们会碰上这种情况,即在if中判断数组或对象是否为空。如果直接判断的话,依据之前的理论,不管是不是空数组或对象最后都是true,因为数组或对象会强制转换为true。

判断数组是否为空很简单,只需要访问它的length属性即可。那对象该怎么办?

这里可以使用Object.keys方法对对象属性进行遍历,该方法返回一个包含对象属性的数组,如果数组长度为0,即代表为空。当然,这种情况并不完全严谨,因为,对象可能存在不可枚举属性。

var arr = []
arr.length = 0
var obj = {}
Object.keys(obj).length = 0

总结

以上所述是小编给大家介绍的JS在if中的强制类型转换,希望对大家有所帮助,如果对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的

Javascript 相关文章推荐
cnblogs TagCloud基于jquery的实现代码
Jun 11 Javascript
javascript 保存文件到本地实现方法
Nov 29 Javascript
IE、FF、Chrome浏览器中的JS差异介绍
Aug 13 Javascript
JavaScript原生对象之Number对象的属性和方法详解
Mar 13 Javascript
tuzhu_req.js 实现仿百度图片首页效果
Aug 11 Javascript
jquery实现点击变换导航样式的方法
Aug 31 Javascript
基于jQuery1.9版本如何判断浏览器版本类型
Jan 12 Javascript
JS中split()用法(将字符串按指定符号分割成数组)
Oct 24 Javascript
jQuery Ajax 实现在html页面实时显示用户登录状态
Dec 30 Javascript
vue router路由嵌套不显示问题的解决方法
Jun 17 Javascript
JavaScript使用Math.random()生成简单的验证码
Jan 21 Javascript
微信小程序 导入图标实现过程详解
Oct 11 Javascript
微信小程序form表单组件示例代码
Jul 15 #Javascript
微信小程序仿朋友圈发布动态功能
Jul 15 #Javascript
Bootstrap Table中的多选框删除功能
Jul 15 #Javascript
详解JavaScript 中 if / if...else...替换方式
Jul 15 #Javascript
简述JS控制台的使用
Jul 15 #Javascript
简述JS浏览器的三种弹窗
Jul 15 #Javascript
Vue路由钩子之afterEach beforeEach的区别详解
Jul 15 #Javascript
You might like
Php获取金书网的书名的实现代码
2010/06/11 PHP
PHP IDE phpstorm 常用快捷键
2015/05/18 PHP
关于php微信订阅号开发之token验证后自动发送消息给订阅号但是没有消息返回的问题
2015/12/21 PHP
深入理解JavaScript系列(31):设计模式之代理模式详解
2015/03/03 Javascript
js实现适用于素材网站的黑色多级菜单导航条效果
2015/08/24 Javascript
NodeJS使用formidable实现文件上传
2016/10/27 NodeJs
jquery封装插件时匿名函数形参和实参的写法解释
2017/02/14 Javascript
js鼠标跟随运动效果
2017/03/11 Javascript
Js中async/await的执行顺序详解
2017/09/22 Javascript
vue内置指令详解
2018/04/03 Javascript
详解微信JS-SDK选择图片遇到的坑
2018/08/15 Javascript
node使用Mongoose类库实现简单的增删改查
2018/11/08 Javascript
详解Bootstrap 学习(一)入门
2019/04/12 Javascript
通过JS深度判断两个对象字段相同
2019/06/14 Javascript
vue中typescript装饰器的使用方法超实用教程
2019/06/17 Javascript
关于微信小程序map组件z-index的层级问题分析
2019/07/09 Javascript
[36:16]完美世界DOTA2联赛PWL S3 access vs Rebirth 第一场 12.19
2020/12/24 DOTA
Django模板变量如何传递给外部js调用的方法小结
2017/07/24 Python
python对配置文件.ini进行增删改查操作的方法示例
2017/07/28 Python
Python with语句上下文管理器两种实现方法分析
2018/02/09 Python
Python使用matplotlib和pandas实现的画图操作【经典示例】
2018/06/13 Python
Python中pandas dataframe删除一行或一列:drop函数详解
2018/07/03 Python
Python range、enumerate和zip函数用法详解
2019/09/11 Python
使用Python为中秋节绘制一块美味的月饼
2019/09/11 Python
python中子类与父类的关系基础知识点
2021/02/02 Python
武汉某公司的C#笔试题面试题
2015/12/25 面试题
数控加工专业毕业生自荐信
2013/09/27 职场文书
办公文员的工作岗位职责
2013/11/12 职场文书
大堂副理的岗位职责范文
2014/02/17 职场文书
高中升旗仪式演讲稿
2014/09/09 职场文书
教育局党的群众路线教育实践活动整改方案
2014/09/20 职场文书
小学教育见习报告
2014/10/31 职场文书
周年庆典答谢词
2015/01/20 职场文书
解除处分决定书
2015/06/25 职场文书
小学大队干部竞选稿
2015/11/20 职场文书
Mysql服务添加 iptables防火墙策略的方案
2021/04/29 MySQL