js判断undefined类型,undefined,null, 的区别详细解析


Posted in Javascript onDecember 16, 2013

js判断undefined类型

今天使用showModalDialog打开页面,返回值时。当打开的页面点击关闭按钮或直接点浏览器上的关闭则返回值是undefined
所以自作聪明判断  

var reValue=window.showModalDialog("","","");
  if (reValue== undefined){
  alert("undefined");
 }

发现判断不出来,最后查了下资料要用typeof

方法:
if (typeof(reValue) == "undefined") {
    alert("undefined");
}  
typeof 返回的是字符串,有六种可能:"number"、"string"、"boolean"、"object"、"function"、"undefined"

js中undefined,null,NaN的区别

1.类型分析:
js中的数据类型有undefined,boolean,number,string,object等5种,前4种为原始类型,第5种为引用类型。
var a1;
var a2 = true;
var a3 = 1;
var a4 = "Hello";
var a5 = new Object();
var a6 = null;
var a7 = NaN;
var a8 = undefined;
alert(typeof a);    //显示"undefined"
alert(typeof a1); //显示"undefined"
alert(typeof a2); //显示"boolean"
alert(typeof a3); //显示"number"
alert(typeof a4); //显示"string"
alert(typeof a5); //显示"object"
alert(typeof a6); //显示"object"
alert(typeof a7); //显示"number"
alert(typeof a8); //显示"undefined"

从上面的代码中可以看出未定义的值和定义未赋值的为undefined,null是一种特殊的object,NaN是一种特殊的number。

2.比较运算
var a1;         //a1的值为undefined
var a2 = null;
var a3 = NaN;
alert(a1 == a2); //显示"true"
alert(a1 != a2); //显示"false"
alert(a1 == a3); //显示"false"
alert(a1 != a3); //显示"true"
alert(a2 == a3); //显示"false"
alert(a2 != a3); //显示"true"
alert(a3 == a3); //显示"false"
alert(a3 != a3); //显示"true"

从上面的代码可以得出结论:(1)undefined与null是相等;(2)NaN与任何值都不相等,与自己也不相等。

JavaScript undefined 属性

定义和用法
undefined 属性用于存放 JavaScript 的 undefined 值。

语法
undefined

说明
无法使用 for/in 循环来枚举 undefined 属性,也不能用 delete 运算符来删除它。
undefined 不是常量,可以把它设置为其他值。
当尝试读取不存在的对象属性时也会返回 undefined。

提示和注释
提示:只能用 === 运算来测试某个值是否是未定义的,因为 == 运算符认为 undefined 值等价于 null。
注释:null 表示无值,而 undefined 表示一个未声明的变量,或已声明但没有赋值的变量,或一个并不存在的对象属性。

实例
在本例中,我们将检测两个变量中未定义的一个:
<script type="text/javascript">
var t1=""
var t2
if (t1===undefined) {document.write("t1 is undefined")}
if (t2===undefined) {document.write("t2 is undefined")}
</script>

输出:
t2 is undefined

Javascript 相关文章推荐
jquery实现的让超出显示范围外的导航自动固定屏幕最顶上
Sep 22 Javascript
node.js+Ajax实现获取HTTP服务器返回数据
Nov 26 Javascript
javascript实现单击和双击并存的方法
Dec 13 Javascript
JavaScript 数组some()和filter()的用法及区别
May 20 Javascript
jQuery+ajax读取并解析XML文件的方法
Sep 09 Javascript
用file标签实现多图文件上传预览
Feb 14 Javascript
yii form 表单提交之前JS在提交按钮的验证方法
Mar 15 Javascript
easyui-edatagrid.js实现回车键结束编辑功能的实例
Apr 12 Javascript
Vue实例中生命周期created和mounted的区别详解
Aug 25 Javascript
bootstrap table实现双击可编辑、添加、删除行功能
Sep 27 Javascript
JavaScript数据结构之优先队列与循环队列实例详解
Oct 27 Javascript
Jquery+AJAX实现无刷新上传并重命名文件操作示例【PHP后台接收】
May 29 jQuery
innerHTML,outerHTML,innerText,outerText的用法及区别解析
Dec 16 #Javascript
js AppendChild与insertBefore用法详细对比
Dec 16 #Javascript
js中AppendChild与insertBefore的用法详细解析
Dec 16 #Javascript
JS获取月的最后一天与JS得到一个月份最大天数的实例代码
Dec 16 #Javascript
JS控件ASP.NET的treeview控件全选或者取消(示例代码)
Dec 16 #Javascript
JS冒泡事件的快速解决方法
Dec 16 #Javascript
JS批量操作CSS属性详细解析
Dec 16 #Javascript
You might like
php 常用字符串函数总结
2008/03/15 PHP
网友原创的PHP模板类代码
2008/09/07 PHP
PHP开发中常用的三个表单验证函数使用小结
2010/03/03 PHP
PHP模板引擎Smarty中的保留变量用法分析
2016/04/11 PHP
PHP 极验验证码实例讲解
2016/09/29 PHP
jquery.fileEveryWhere.js 一个跨浏览器的file显示插件
2011/10/24 Javascript
jQuery下通过replace字符串替换实现大小图片切换
2012/05/22 Javascript
jquery通过select列表选择框对表格数据进行过滤示例
2014/05/07 Javascript
angular简介和其特点介绍
2015/01/29 Javascript
JavaScript实现的双向跨域插件分享
2015/01/31 Javascript
理解javascript中的Function.prototype.bind的方法
2017/02/03 Javascript
浅谈angular2 组件的生命周期钩子
2017/08/12 Javascript
p5.js 毕达哥拉斯树的实现代码
2018/03/23 Javascript
对layui中table组件工具栏的使用详解
2019/09/19 Javascript
CountUp.js数字滚动插件使用方法详解
2019/10/17 Javascript
vue 实现cli3.0中使用proxy进行代理转发
2019/10/30 Javascript
python2.7删除文件夹和删除文件代码实例
2013/12/18 Python
python实现超简单端口转发的方法
2015/03/13 Python
python根据txt文本批量创建文件夹
2020/12/08 Python
浅析PyTorch中nn.Linear的使用
2019/08/18 Python
Python SELENIUM上传文件或图片实现过程
2019/10/28 Python
使用 PyTorch 实现 MLP 并在 MNIST 数据集上验证方式
2020/01/08 Python
Python基于百度AI实现OCR文字识别
2020/04/02 Python
南非领先的在线旅行社:Travelstart南非
2016/09/04 全球购物
C语言编程题
2015/03/09 面试题
党员思想汇报范文
2013/12/30 职场文书
总裁办公室主任职责
2014/01/02 职场文书
如何写一份好的英文求职信
2014/03/19 职场文书
2014年清明节网上祭英烈寄语
2014/04/09 职场文书
义和团口号
2014/06/17 职场文书
业务员辞职信范文
2015/03/02 职场文书
幼儿园教师工作总结2015
2015/04/02 职场文书
毕业设计论文致谢词
2015/05/14 职场文书
抢劫罪辩护词
2015/05/21 职场文书
工程移交协议书
2016/03/24 职场文书
详解Spring Security中的HttpBasic登录验证模式
2022/03/17 Java/Android