举例讲解如何判断JavaScript中对象的类型


Posted in Javascript onApril 22, 2016

在编写js程序的过程中,可能常常需要判断一个对象的类型,例如你写了一个函数,需要通过判断不同的参数类型来编写不同的代码。
首先可能会想到typeof操作符,看下面的这个例子:

<script type="text/javascript"> 
var object = {}; 
var b = true; 
alert(typeof object + " " + typeof b); 
 </script>

得到的结果如下:

举例讲解如何判断JavaScript中对象的类型

从上面的结果可以看到,用typeof操作符可以显示对象的类型,那么typeof操作符作用域null和undefined的结果会是什么呢?

/*var object = {}; 
var b = true; 
alert(typeof object + " " + typeof b);*/ 
alert(typeof null + " " + typeof undefined)

举例讲解如何判断JavaScript中对象的类型

typeof 操作符作用于null居然显示”object“(这个好像不科学,我还以为会显示”null'“),作用于undefined显示”undefined“(这个符合我们希望的结果),所以当用typeof操作符来判断一个对象的类型时,特别要小心,因为这个对象有可能是null。上面只是给了一部分typeof作用于这些对象的结果,下面的表列出了typeof操作符作用于Boolean, Number, String, Array, Date, RegExp, Object, Function, null, undefined的结果(有兴趣的读者可以自行测试):

举例讲解如何判断JavaScript中对象的类型

从上表的结果可以看出Array, Date, RegExp显示的都是object,为什么不是直接的显示对象的类型呢?这就要引出js的另外一个操作符了:instanceof操作符,这个操作符用来判断一个对象是否为某种类型的对象,计算的值为true或者false。先来看下:

var now = new Date(); 
var pattern = /^[\s\S]*$/; 
var names = ['zq', 'john']; 
alert((now instanceof Date) + " " 
 + (pattern instanceof RegExp) + " " + (names instanceof Array));

举例讲解如何判断JavaScript中对象的类型

很显然通过这个instanceof是能判断对象的类型的,但是这个只能判断除了基本类型(包含String类型)的其它类型,他是不能判断基本类型的。但是instanceof不是总是能正常判断的,考虑一个框架的情形,要判断其类型的对象是另外一个frame传递过来的对象,首先来看下下面的例子。
main.html

<!doctype html> 
<html lang="en"> 
 <head> 
 <title>Main</title> 
 </head> 
 <frameset cols="45%,*"> 
  <frame name="frame1" src="frame1.html"/> 
  <frame name="frame2" src="frame2.html"/> 
 </frameset> 
</html>

frame1.html

<!doctype html> 
<html lang="en"> 
 <head> 
 <meta charset="UTF-8"> 
 <title>frame1</title> 
 </head> 
 <script type="text/javascript"> 
 var names = ['riccio zhang', 'zq', 'john']; 
 </script> 
 <body style="background: #ccc"> 
 
 </body> 
</html>

frame2.html

<!doctype html> 
<html lang="en"> 
 <head> 
 <meta charset="UTF-8"> 
 <title>frame2</title> 
 <script type="text/javascript"> 
 document.write("top.frame1.names instanceof Array:" 
  + (top.frame1.names instanceof Array)); 
 document.write("<br/>"); 
 document.write("top.frame1.names instanceof top.frame1.Array:" 
  + (top.frame1.names instanceof top.frame1.Array)); 
 document.write("<br/>"); 
 document.write("top.frame1.Array === top.frame2.Array?" + (top.frame1.Array === top.frame2.Array)); 
 </script> 
 </head> 
 <body style="background: #747474"> 
 
 </body> 
</html>

举例讲解如何判断JavaScript中对象的类型

names对象是在frame1框架中的,此时是通过frame1框架的Array来创建的,如果把names对象拿到frame2中的Array作比较,很显然names不是frame2中的Array的实例,以为frame1和frame2压根就不是同一和Array,从第2个现实结果可以很明显的看出names是他本身所在的frame的实例,从第3个输出可以看出frame1的Array和frame2的Array是不同的。那么遇到上面这种跨frame的比较该怎么办呢?我们总不能每次都拿框架对应的Array来做比较吧,有一种必须的办法可以解决上面的问题,看下面的代码:

var toString = {}.toString; 
var now = new Date(); 
alert(toString.call(now))

举例讲解如何判断JavaScript中对象的类型

{}.toString表示获取Object对象上的toString方法(这个方法时Object对象的基本方法之一),toString.call(now)表示调用toString方法。调用Date对象最原生的toString()(这个方法是Object上面的方法)方法可以显示[object Date]类型的字符串,假如是Array,则会产生[object Array]的字样,也就是说进行上面的操作会显示类似[object Class]的字样,那么我们只要判断这个字符串不就可以知道其类型了吗?由此可以写出如下的工具类:
tools.js

var tools = (function(undefined){ 
 var class2type = {}, 
  toString = {}.toString; 
  
 var fun = { 
  type: function (obj){ 
   return obj === null || obj === undefined ? 
      String(obj) : class2type[toString.call(obj)] 
  }, 
  isArray: function (obj){ 
   return fun.type(obj) === "array"; 
  }, 
  isFunction: function (obj){ 
   return fun.type(obj) === "function"; 
  }, 
  each: function (arr, callback){ 
   var i = 0, 
    hasLength = arr.length ? true : false; 
   if(!callback || (typeof callback !== 'function') || !hasLength){ 
    return; 
   } 
   for(i = 0; i< arr.length; i++){ 
    if(callback.call(arr[i], i, arr[i]) === false){ 
      break; 
    } 
   } 
  } 
 }; 
 fun.each("Boolean Number String Array Date RegExp Object Function".split(" "), function(i, name){ 
  class2type["[object "+ name +"]"] = name.toLowerCase(); 
 }); 
 return fun; 
})();

tools提供了type,isArray,isFunction等方法用来判断对象的类型,根据实际的需要可以自己添加需要判断类型的方法。type接受一个obj参数,它将对象的实际类型以小写的形式返回,比如你的需要判断对象的类型是Array,那么此方法将会返回array.
根据上面提供的工具类,再重新改写上面的例子:
fram2.html

<!doctype html> 
<html lang="en"> 
 <head> 
 <meta charset="UTF-8"> 
 <title>frame2</title> 
 <script type="text/javascript" src="tools.js"></script> 
 <script type="text/javascript"> 
 document.write("top.frame1.names instanceof Array:" 
  + (top.frame1.names instanceof Array)); 
 document.write("<br/>"); 
 document.write("top.frame1.names instanceof top.frame1.Array:" 
  + (top.frame1.names instanceof top.frame1.Array)); 
 document.write("<br/>"); 
 document.write("top.frame1.Array === top.frame2.Array?" + (top.frame1.Array === top.frame2.Array)); 
 document.write("<br/>"); 
 document.write("tools.isArray(top.frame1.names)?" + tools.isArray(top.frame1.names)); 
 </script> 
 </head> 
 <body style="background: #747474"> 
 
 </body> 
</html>

举例讲解如何判断JavaScript中对象的类型

至此通过上面的根据类就可以很容易的判断对象的类型了。
注意:在IE中例如像alert这样的元素是不能判断的。

Javascript 相关文章推荐
Javascript 个人笔记(没有整理,很乱)
Jul 07 Javascript
JavaScript异步编程:异步数据收集的具体方法
Aug 19 Javascript
JavaScript控制网页层收起和展开效果的方法
Apr 15 Javascript
简单介绍JavaScript的变量和数据类型
Jun 03 Javascript
JavaScript html5 canvas绘制时钟效果(二)
Mar 27 Javascript
基于BootStrap Metronic开发框架经验小结【六】对话框及提示框的处理和优化
May 12 Javascript
AngularJs篇:使用AngularJs打造一个简易权限系统的实现代码
Dec 26 Javascript
JavaScript使用delete删除数组元素用法示例【数组长度不变】
Jan 17 Javascript
JavaScript实现简单图片轮播效果
Aug 21 Javascript
vue中引用swiper轮播插件的教程详解
Aug 16 Javascript
vue实现添加与删除图书功能
Oct 07 Javascript
nuxt 路由、过渡特效、中间件的实现代码
Nov 06 Javascript
使用jQuery制作基础的Web图片轮播效果
Apr 22 #Javascript
使用jQuery UI库开发Web界面的简单入门指引
Apr 22 #Javascript
jQuery 监控键盘一段时间没输入
Apr 22 #Javascript
基于jquery实现轮播特效
Apr 22 #Javascript
jquery插件Jplayer使用方法简析
Apr 22 #Javascript
jQuery点击其他地方时菜单消失的实现方法
Apr 22 #Javascript
JS验证逗号隔开可以是中文字母数字
Apr 22 #Javascript
You might like
php的memcached客户端memcached
2011/06/14 PHP
php中实现简单的ACL 完结篇
2011/09/07 PHP
php随机输出名人名言的代码
2012/10/07 PHP
php缩小png图片不损失透明色的解决方法
2013/12/25 PHP
php实现改变图片直接打开为下载的方法
2015/04/14 PHP
PHP使用Curl实现模拟登录及抓取数据功能示例
2018/04/27 PHP
IE8 chrome中table隔行换色解决办法
2010/07/09 Javascript
jquery中加载图片自适应大小主要实现代码
2013/08/23 Javascript
JS中的this变量的使用介绍
2013/10/21 Javascript
jquery mobile的触控点击事件会多次触发问题的解决方法
2014/05/08 Javascript
Jquery焦点图实例代码
2014/11/25 Javascript
Nodejs中的this详解
2016/03/26 NodeJs
JS获取元素多层嵌套思路详解
2016/05/16 Javascript
JS集成fckeditor及判断内容是否为空的方法
2016/05/27 Javascript
jQuery设置聚焦并使光标位置在文字最后的实现方法
2016/08/02 Javascript
jQuery实现输入框邮箱内容自动补全与上下翻动显示效果【附demo源码下载】
2016/09/20 Javascript
详解axios在vue中的简单配置与使用
2017/05/10 Javascript
浅谈vue-cli 3.0.x 初体验
2018/04/11 Javascript
浅谈vue websocket nodeJS 进行实时通信踩到的坑
2020/09/22 NodeJs
[01:21:07]EG vs Liquid 2018国际邀请赛淘汰赛BO3 第一场 8.25
2018/08/29 DOTA
[43:43]完美世界DOTA2联赛PWL S2 LBZS vs Forest 第三场 11.29
2020/12/02 DOTA
python用pickle模块实现“增删改查”的简易功能
2017/06/07 Python
解决win64 Python下安装PIL出错问题(图解)
2018/09/03 Python
TensorFlow实现Logistic回归
2018/09/07 Python
python判断数字是否是超级素数幂
2018/09/27 Python
Python实现对字典分别按键(key)和值(value)进行排序的方法分析
2018/12/19 Python
浅谈TensorFlow之稀疏张量表示
2020/06/30 Python
Django模板报TemplateDoesNotExist异常(亲测可行)
2020/12/18 Python
10种CSS3实现的loading动画,挑一个走吧?
2020/11/16 HTML / CSS
德国机车企业:FC-Moto
2017/10/27 全球购物
罗技英国官方网站:Logitech UK
2020/11/03 全球购物
酒店管理毕业生自荐信
2013/10/24 职场文书
数控专业大学生的自我鉴定
2013/11/13 职场文书
土地租赁协议书
2015/01/29 职场文书
党支部工作总结2015
2015/04/01 职场文书
如何用PHP实现分布算法之一致性哈希算法
2021/05/26 PHP