js对象类型检查(续)
发布日期:2021-09-30 04:14:38 浏览次数:1 分类:技术文章

本文共 898 字,大约阅读时间需要 2 分钟。

上一篇文章,我讲到了使用typeof和constructor两种方法来进行对象类型的判断。其中,typeof可以说是js设计上的一个缺陷,因为几乎不可能从它那里得到想要的结果,它唯一的使用场景就是判断一个变量是否已经定义,如typeof para==='undefined',因此,一般情况下不要用它来进行对象类型的检查。

         而constructor是一个很有用处的属性,它能够正确的得到我们期望的结果,但是,它返回的是一个对象。

         今天,介绍另外一个方法来实现对象类型的判断。这是javascript标准文档中给出的方法,就是使用Object.property.toString.call。首先来看一下这个方法返回的结果:  

Object.prototype.toString.call([]);//[Object Array]Object.prototype.toString.call({});//[Object Object]Object.prototype.toString.call(2);//[Object Number]Object.prototype.toString.call("2");//[Object String]Object.prototype.toString.call(function (){});//[Object Function]
       可见,它确实能正确地返回我们所期望的结果,但是在我们写代码的时候,如果拿这个返回值去做判断的话,会很麻烦(因为它太长了,并且我们只需要后面一部分)。如果才能得到该结果中我们所需要的那部分呢?用下面的函数可以实现:

 function is(type, obj) {  

var clas = Object.prototype.toString.call(obj).slice(8, -1);  

return obj !== undefined && obj !== null && clas === type;

}

其中,type是我们所期望的类型,而obj是我们所要判断类型的对象。。
is("Array",[1,2]);//true

转载地址:https://blog.csdn.net/huli870715/article/details/6876841 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:linux文件权限系统之初体验
下一篇:JS数组的赋值

发表评论

最新留言

不错!
[***.144.177.141]2024年04月13日 05时08分48秒