JS中typeof与instanceof之间的区别总结


Posted in Javascript onNovember 14, 2013

JavaScript 中 typeof 和 instanceof 常用来判断一个变量是否为空,或者是什么类型的。但它们之间还是有区别的:

typeof

typeof 是一个一元运算,放在一个运算数之前,运算数可以是任意类型。

它返回值是一个字符串,该字符串说明运算数的类型。typeof 一般只能返回如下几个结果:

number,boolean,string,function,object,undefined。我们可以使用 typeof 来获取一个变量是否存在,如 if(typeof a!="undefined"){alert("ok")},而不要去使用 if(a) 因为如果 a 不存在(未声明)则会出错,对于 Array,Null 等特殊对象使用 typeof 一律返回 object,这正是 typeof 的局限性。

instanceof

instance:实例,例子

a instanceof b?alert("true"):alert("false"); //a是b的实例?真:假

instanceof 用于判断一个变量是否某个对象的实例,如 var a=new Array();alert(a instanceof Array);
会返回 true,同时 alert(a instanceof Object) 也会返回 true;这是因为 Array 是 object
的子类。再如:function test(){};var a=new test();alert(a instanceof test) 会返回

谈到 instanceof 我们要多插入一个问题,就是 function 的 arguments,我们大家也许都认为 arguments 是一个
Array,但如果使用 instaceof 去测试会发现 arguments 不是一个 Array 对象,尽管看起来很像。

另外:

测试 var a=new Array();if (a instanceof Object) alert('Y');else alert('N');

得'Y'

但 if (window instanceof Object) alert('Y');else alert('N');

得'N'

所以,这里的 instanceof 测试的 object 是指 js 语法中的 object,不是指 dom 模型对象。

使用 typeof 会有些区别

alert(typeof(window)) 会得 object

Javascript 相关文章推荐
JavaScript入门教程(8) Location地址对象
Jan 31 Javascript
JavaScript 反科里化 this [译]
Sep 20 Javascript
JavaScript操纵窗口的方法小结
Jun 28 Javascript
IE10中flexigrid无法显示数据的解决方法
Jul 26 Javascript
jquery实现仿新浪微博评论滚动效果
Aug 06 Javascript
详解JavaScript中localStorage使用要点
Jan 13 Javascript
使用Ajax生成的Excel文件并下载的实例
Nov 21 Javascript
bootstrap模态框实现拖拽效果
Dec 14 Javascript
angularjs中ng-attr的用法详解
Dec 31 Javascript
Vue3.0结合bootstrap创建多页面应用
May 28 Javascript
浅谈一个webpack构建速度优化误区
Jun 24 Javascript
js实现贪吃蛇小游戏
Oct 29 Javascript
jQuery探测位置的提示弹窗(toolTip box)详细解析
Nov 14 #Javascript
使用jQuery解决IE与FireFox下createElement方法的差异
Nov 14 #Javascript
浅析用prototype定义自己的方法
Nov 14 #Javascript
Js nodeType 属性全面解析
Nov 14 #Javascript
open 动态修改img的onclick事件示例代码
Nov 13 #Javascript
解决jquery1.9不支持browser对象的问题
Nov 13 #Javascript
js获取IFRAME当前的URL的方法
Nov 13 #Javascript
You might like
56.com视频采集接口程序(PHP)
2007/09/22 PHP
php遍历解析xml字符串的方法
2016/05/05 PHP
php使用mysqli和pdo扩展,测试对比连接mysql数据库的效率完整示例
2019/05/09 PHP
jQuery textarea的长度进行验证
2009/05/06 Javascript
jquery png 透明解决方案(推荐)
2010/08/21 Javascript
通过JQuery实现win8一样酷炫的动态磁贴效果(示例代码)
2013/07/13 Javascript
用jQuery模拟select下拉框的简单示例代码
2014/01/26 Javascript
jquery中$each()方法的使用指南
2015/04/30 Javascript
Js 获取当前函数参数对象的实现代码
2016/06/20 Javascript
从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例
2017/04/13 Javascript
easyui combogrid实现本地模糊搜索过滤多列
2017/05/13 Javascript
AngularJS 实现点击按钮获取验证码功能实例代码
2017/07/13 Javascript
vue 搭建后台系统模块化开发详解
2019/05/01 Javascript
Layui给switch添加响应事件的例子
2019/09/03 Javascript
jQuery cookie的公共方法封装和使用示例
2020/06/01 jQuery
vue3自定义dialog、modal组件的方法
2021/01/04 Vue.js
[01:14:10]2014 DOTA2国际邀请赛中国区预选赛 SPD-GAMING VS Orenda
2014/05/22 DOTA
[03:00]2018完美盛典_最佳英雄奖
2018/12/17 DOTA
编写Python脚本批量下载DesktopNexus壁纸的教程
2015/05/06 Python
Python函数式编程指南(四):生成器详解
2015/06/24 Python
Python 判断 有向图 是否有环的实例讲解
2018/02/01 Python
Python开发之Nginx+uWSGI+virtualenv多项目部署教程
2019/05/13 Python
python 在某.py文件中调用其他.py内的函数的方法
2019/06/25 Python
Python如何把十进制数转换成ip地址
2020/05/25 Python
意大利辅助药品、药物和补品在线销售:FarmaEurope
2020/04/29 全球购物
工商管理本科毕业生求职信范文
2013/10/05 职场文书
营销总经理的岗位职责
2013/12/15 职场文书
保护环境的标语
2014/06/09 职场文书
幼儿教师2014年度工作总结
2014/12/16 职场文书
2016参观监狱警示教育活动心得体会
2016/01/15 职场文书
《中国古代诗歌散文欣赏》高中语文教材
2019/08/20 职场文书
使用Pytorch实现two-head(多输出)模型的操作
2021/05/28 Python
解决Mysql的left join无效及使用的注意事项说明
2021/07/01 MySQL
Opencv实现二维直方图的计算及绘制
2021/07/21 Python
springcloud整合seata
2022/05/20 Java/Android