区分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 相关文章推荐
细品javascript 寻址,闭包,对象模型和相关问题
Apr 27 Javascript
JS setCapture 区域外事件捕捉
Mar 18 Javascript
ExtJS 设置级联菜单的默认值
Jun 13 Javascript
基于jquery跨浏览器显示的file上传控件
Oct 24 Javascript
Node.js中child_process实现多进程
Feb 03 Javascript
JavaScript创建一个object对象并操作对象属性的用法
Mar 23 Javascript
javascript实现树形菜单的方法
Jul 17 Javascript
AngularJs  unit-testing(单元测试)详解
Sep 02 Javascript
几种tab切换详解
Feb 03 Javascript
使用Vue制作图片轮播组件思路详解
Mar 21 Javascript
JS基于Location实现访问Url、重定向及刷新页面的方法分析
Dec 03 Javascript
使用Vue实现移动端左滑删除效果附源码
May 16 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
Zend公司全球首推PHP认证
2006/10/09 PHP
PHP高级对象构建 工厂模式的使用
2012/02/05 PHP
php metaphone()函数及php localeconv() 函数实例解析
2016/05/15 PHP
PHP list() 将数组中的值赋给变量的简单实例
2016/06/13 PHP
推荐dojo学习笔记
2007/03/24 Javascript
JavaScript如何从listbox里同时删除多个项目
2013/10/12 Javascript
详解webpack多页面配置记录
2018/01/22 Javascript
angular json对象push到数组中的方法
2018/02/27 Javascript
Webpack的dll功能使用
2018/06/28 Javascript
vue权限路由实现的方法示例总结
2018/07/29 Javascript
Python XML RPC服务器端和客户端实例
2014/11/22 Python
python使用Queue在多个子进程间交换数据的方法
2015/04/18 Python
Python实现一个简单的验证码程序
2017/11/03 Python
利用Python如何将数据写到CSV文件中
2018/06/05 Python
利用django-suit模板添加自定义的菜单、页面及设置访问权限
2018/07/13 Python
python散点图实例之随机漫步
2018/08/27 Python
Python设计模式之解释器模式原理与用法实例分析
2019/01/10 Python
Python获取数据库数据并保存在excel表格中的方法
2019/06/12 Python
python下载库的步骤方法
2019/10/12 Python
Python类如何定义私有变量
2020/02/03 Python
python实现图片转字符画的完整代码
2021/02/21 Python
CSS中越界问题的经典解决方案【推荐】
2016/04/19 HTML / CSS
阿拉伯世界最大的电子商务网站:Souq沙特阿拉伯
2016/10/28 全球购物
Zavvi美国:英国娱乐之家
2017/03/19 全球购物
如何获取某个日期是当月的最后一天
2013/12/05 面试题
do you have any Best Practice for testing
2016/06/04 面试题
机械系大学毕业生推荐信
2013/11/27 职场文书
高中体育教学反思
2014/01/24 职场文书
爱情保证书大全
2014/04/29 职场文书
孝敬父母的演讲稿
2014/05/14 职场文书
优质服务口号
2014/06/11 职场文书
物流专业求职信
2014/06/30 职场文书
机电一体化应届生求职信
2014/08/09 职场文书
农村文化活动总结
2014/08/28 职场文书
出生医学证明书
2014/09/15 职场文书
老龙头导游词
2015/02/11 职场文书