区分JS中的undefined,null,"",0和false


Posted in Javascript onMarch 08, 2007

在程序语言中定义的各种各样的数据类型中,我们都会为其定义一个"空值"或"假值",比如对象类型的空值null,.NET Framework中数据库字段的空值DBNull,boolean类型的假值false等等。在JavaScript中也有很多种的"空值"和"假值",那么它们都有什么共同点和不同点呢?

    其实标题里面我已经列出了JavaScript中所有的"空值"和"假值",除了boolean值本身就是true和false这两种情况外,其它数据类型的"空值"主要是undefined和defined这两大类。这些空值的类型分别是: 

 typeof(undefined) == 'undefined'  
 typeof(null) == 'object'  
 typeof("") == 'string'  
 typeof(0) == 'number'  
 typeof(false) == 'boolean' 

    这五个值的共同点是,在if语句中做判断,都会执行false分支。当然从广义上来看,是说明这些数值都是其对应数据类型上的无效值或空值。还有这五个值作!运算,结果全为:true。

    这几个值中也有不同,其中undefined和null比较特殊,虽然null的类型是object,但是null不具有任何对象的特性,就是说我们并不能执行null.toString()、null.constructor等对象实例的默认调用。所以从这个意义上来说,null和undefined有最大的相似性。看看null == undefined的结果(true)也就更加能说明这点。不过相似归相似,还是有区别的,就是和数字运算时,10 + null结果为:10;10 + undefined结果为:NaN。

    另外""、0和false虽然在if语句表现为"假值",可它们都是有意义数据,只是被作为了"空值"或"假值",因为:"".toString(),(0).toString()和false.toString()都是合法的可执行表达式。

    其实这5个值在上面所说的这些差异里,并不太会给程流程控制带来太大的问题,那么要区分它们什么呢?需要注意区分的是这些值在转换为String时的差异是比较大的,它们到String的转换关系是: 

 String(undefined) -> "undefined"  
 String(null) -> "null"  
 String("") -> ""  
 String(0) -> "0"  
 String(false) -> "false" 

    这个转换关系在做字符串累加时需要特别的注意,否这会出些意想不到的问题,今天就遇到一个null被默认转为"null"给弄得迷糊了好一阵子。
Javascript 相关文章推荐
封装好的省市地区联动控件附下载
Aug 13 Javascript
JavaScript 序列化对象实现代码
Dec 18 Javascript
使用javascript:将其它类型值转换成布尔类型值的解决方法详解
May 07 Javascript
jQuery实现类似淘宝购物车全选状态示例
Jun 26 Javascript
使用js 设置url参数
Jul 08 Javascript
javascript实现当前页导航激活的方法
Feb 27 Javascript
JS限制文本框只能输入数字和字母方法
Feb 28 Javascript
浅谈angular懒加载的一些坑
Aug 20 Javascript
Vue中的数据监听和数据交互案例解析
Jul 12 Javascript
前后端如何实现登录token拦截校验详解
Sep 03 Javascript
解决vue热替换失效的根本原因
Sep 19 Javascript
JS代码编译器Monaco使用方法
Jun 11 Javascript
在JavaScript中使用inline函数的问题
Mar 08 #Javascript
JS类中定义原型方法的两种实现的区别
Mar 08 #Javascript
JavaScript语言中的Literal Syntax特性分析
Mar 08 #Javascript
从JavaScript的函数重名看其初始化方式
Mar 08 #Javascript
翻译整理的jQuery使用查询手册
Mar 07 #Javascript
用window.location.href实现刷新另个框架页面
Mar 07 #Javascript
javascript中的location用法简单介绍
Mar 07 #Javascript
You might like
基于PHP实现商品成交时发送短信功能
2016/05/11 PHP
关于PHP文件的自动运行方法分析
2016/05/13 PHP
浅谈PHP错误类型及屏蔽方法
2017/05/27 PHP
php获取小程序码的实现代码(B类接口)
2020/06/13 PHP
通过MSXML2自动获取QQ个人头像及在线情况(给初学者)
2007/01/22 Javascript
javascript动态添加表格数据行(ASP后台数据库保存例子)
2010/05/08 Javascript
往光标所在位置插入值的js代码
2013/09/22 Javascript
下拉列表select 由左边框移动到右边示例
2013/12/04 Javascript
jQuery学习笔记之总体架构
2014/06/03 Javascript
input标签内容改变的触发事件介绍
2014/06/18 Javascript
Javascript基础教程之数据类型 (字符串 String)
2015/01/18 Javascript
JS实现无限级网页折叠菜单(类似树形菜单)效果代码
2015/09/17 Javascript
讲解JavaScript的Backbone.js框架的MVC结构设计理念
2016/02/14 Javascript
Jquery为DIV添加click事件的简单实例
2016/06/02 Javascript
妙用Bootstrap的 popover插件实现校验表单提示功能
2016/08/29 Javascript
微信小程序 仿美团分类菜单 swiper分类菜单
2017/04/12 Javascript
Angular.js组件之input mask对input输入进行格式化详解
2017/07/10 Javascript
vue-router 导航钩子的具体使用方法
2017/08/31 Javascript
微信小程序自定义键盘 内部虚拟支付
2018/12/20 Javascript
jquery将json转为数据字典的实例代码
2019/10/11 jQuery
在VUE中实现文件下载并判断状态的方法
2019/11/08 Javascript
使用Promise封装小程序wx.request的实现方法
2019/11/13 Javascript
vue3.0 上手体验
2020/09/21 Javascript
vue 如何从单页应用改造成多页应用
2020/10/23 Javascript
Python中变量交换的例子
2014/08/25 Python
Python实现将不规范的英文名字首字母大写
2016/11/15 Python
Hurley官方网站:扎根于海滩生活方式的全球青年文化品牌
2020/05/18 全球购物
求职简历的自我评价怎样写好
2013/10/07 职场文书
英语文学专业学生的自我评价
2013/10/31 职场文书
体育老师的教学自我评价分享
2013/11/19 职场文书
法定代表人授权委托书范文
2014/08/02 职场文书
2015年试用期自我评价范文
2015/03/10 职场文书
导游词之河姆渡遗址博物馆
2019/10/10 职场文书
MySQL查询学习之基础查询操作
2021/05/08 MySQL
如何理解python接口自动化之logging日志模块
2021/06/15 Python
《LOL》“克隆大作战”久违归来 幻灵战队皮肤上线
2022/04/03 其他游戏