举例讲解如何判断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 相关文章推荐
仅IE支持clearAttributes/mergeAttributes方法使用介绍
May 04 Javascript
js中escape对应的C#解码函数 UrlDecode
Dec 16 Javascript
Js动态添加复选框Checkbox的实例方法
Apr 08 Javascript
javascript去除空格方法小结
May 21 Javascript
javascript 动态样式添加的简单实现
Oct 11 Javascript
angularJS利用ng-repeat遍历二维数组的实例代码
Jun 03 Javascript
bootstrap datetimepicker控件位置异常的解决方法
Nov 23 Javascript
seajs下require书写约定实例分析
May 16 Javascript
微信小程序踩坑记录之解决tabBar.list[3].selectedIconPath大小超过40kb
Jul 04 Javascript
ES6 Map结构的应用实例分析
Jun 26 Javascript
基于jsbarcode 生成条形码并将生成的条码保存至本地+源码
Apr 27 Javascript
vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据操作
Jul 31 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
在Laravel5.6中使用Swoole的协程数据库查询
2018/06/15 PHP
Yii2框架控制器、路由、Url生成操作示例
2019/05/27 PHP
PHP Beanstalkd消息队列的安装与使用方法实例详解
2020/02/21 PHP
不使用中间变量,交换int型的 a, b两个变量的值。
2010/10/29 Javascript
IE6中使用position导致页面变形的解决方案(js代码)
2011/01/09 Javascript
基于javascript滚动图片具体实现
2013/11/18 Javascript
javascript数组快速打乱重排的方法
2014/01/02 Javascript
JS获取鼠标相对位置的方法
2016/09/20 Javascript
BootStrop前端框架入门教程详解
2016/12/25 Javascript
JavaScript中正则表达式判断匹配规则及常用方法
2017/08/03 Javascript
JavaScript常用数学函数用法示例
2018/05/14 Javascript
关于vue编译版本引入的问题的解决
2018/09/17 Javascript
解决vue的touchStart事件及click事件冲突问题
2020/07/21 Javascript
Angular利用HTTP POST下载流文件的步骤记录
2020/07/26 Javascript
[02:15]2014DOTA2国际邀请赛 专访LGD.lin小兔子是大腿
2014/07/14 DOTA
windows下安装python paramiko模块的代码
2013/02/10 Python
Python实现端口复用实例代码
2014/07/03 Python
10个易被忽视但应掌握的Python基本用法
2015/04/01 Python
Python根据文件名批量转移图片的方法
2018/10/21 Python
python dlib人脸识别代码实例
2019/04/04 Python
对python中基于tcp协议的通信(数据传输)实例讲解
2019/07/22 Python
Django MEDIA的配置及用法详解
2019/07/25 Python
原生python实现knn分类算法
2019/10/24 Python
如何基于Python制作有道翻译小工具
2019/12/16 Python
提高python代码运行效率的一些建议
2020/09/29 Python
CSS3 真的会替代 SCSS 吗
2021/03/09 HTML / CSS
美国照明、家居装饰和家具购物网站:Bellacor
2017/09/20 全球购物
台湾母婴用品限时团购:妈咪爱
2018/08/03 全球购物
Europcar西班牙:全球汽车租赁领域的领导者
2018/09/17 全球购物
写出二分查找算法的两种实现
2013/05/13 面试题
青年志愿者活动总结
2014/04/26 职场文书
语文高效课堂实施方案
2014/05/03 职场文书
大型活动组织方案
2014/05/10 职场文书
地理科学专业自荐信
2014/09/01 职场文书
小学生优秀评语
2014/12/29 职场文书
解决Goland 同一个package中函数互相调用的问题
2021/05/06 Golang