使用typeof obj===‘object’潜在的问题,并不能确定obj是否是一个对象?

时间: 2018-05-08阅读: 2337标签: 数据

js中我们直接这样写typeof obj === ‘object’ 有什么问题呢?例如下列情况下:

typeof [];  //object
typeof {};  //object
typeof null;  //object


可以看出Array, Object等都会返回的是'object',而且js中令人惊讶的null也被认为是一个对象了! 由此可见使用typeof obj===‘object’并不能准确的判断变量是否为object。为了解决上述情况,我们可以这样来写就能保证判断obj是否为一个对象了。


方法一:

if( (obj !== null) && (typeof  obj   === "object") && (toString.call( obj  ) !== "[object Array]")){
    //code
}


方法二:

上面代码就分别判断了obj不能为null,数组的情况,还有一个替代方法对空值,数组和函数返回false,但对于对象则为true的方法。

if( (obj !== null) && (obj.constructor === Object)) {
    //code
}


方法三:

如果你使用jQuery,可以这样写:

if( (obj !== null) && (typeof  obj   === "object") && (! $.isArray( obj  )) ){
    //code
}


方法四:

使用Object.prototype.toString.call(obj) === "[object Object]"  来判断obj是否为对象,这也是我们项目中最常用的方法,先看下上述三种情况:

console.log(Object.prototype.toString.call({})); //[object Object]
console.log(Object.prototype.toString.call([])); //[object Array]
console.log(Object.prototype.toString.call(null)); //[object Null]

可以看出返回是完全不同,可以放心使用了:

if(  Object.prototype.toString.call(obj) ===  "[object Object]"){ 
 //code
}


站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/739

Js中的数据传输形式JSON和AJAX技术

今天为大家讲解JavaScript中的数据传输形式JSON和AJAX技术。JSON的全称是JavaScript Object Notation(js对象表示法),它是一种存储和交换文本信息的语法,主要用于序列化对象、数组、字符串、Boolean、数字和null

JS实现前端将数据导出excel

方法一将table标签,包括tr、td等对json数据进行拼接,将table输出到表格上实现,这种方法的弊端在于输出的是伪excel,虽说生成xls为后缀的文件,但文件形式上还是html,代码如下

8种常见数据结构及其Javascript实现

做前端的同学不少都是自学成才或者半路出家,计算机基础的知识比较薄弱,尤其是数据结构和算法这块,所以今天整理了一下常见的数据结构和对应的Javascript的实现,希望能帮助大家完善这方面的知识体系。

Highcharts数据量超过1000时无法显示问题

今天在vue的项目中引入Highcharts,想做一个大数据量的实时刷新曲线图,发现当数据量超过1000就无法显示。经过排查发现 Highcharts为了保证更好的性能设置了一个性能阈值检查

使用Proxy实现双向绑定

vue3.0要用Proxy来实现双向绑定,因此先来尝试一下实现方法。原来vue2的实现使用Object.defineProperty,监听set,但对于数组直接下标给数组设置值监听不了。

leetcode 1032. Stream of Characters

用字典树即可解决。首先在init的时候,把words中所有word逆置后存入字典树中;在query的时候,也有逆序的方式记录所有历史query过的值,同时判断其前缀是否存在于字典树中即可。

Vue项目中Api的组织和返回数据处理

项目中的所有Api配置放在一个文件中,便于查找和修改,Api的版本从配置文件(config.js)中读取,采用apiPrefix + url的形式组成。在配置文件中,Api 的配置采用Http请求方式 url的方式

Js数据劫持与数据代理

数据劫持即使用Object.defineProperty()实现了vue的双向绑定。先来看看它是如何实现的;proxy即代理的意思。个人理解,建立一个proxy代理对象(Proxy的实例),接受你要监听的对象和监听它的handle两个参数。

JS最新基本数据类型:BigInt

BigInt数据类型的目的是比Number数据类型支持的范围更大的整数值。在对大整数执行数学运算时,以任意精度表示整数的能力尤为重要。使用BigInt,整数溢出将不再是问题。

vue数据监听与依赖收集

我们在组件钩子函数computed中定义的,都属于这种类型,每一个 computed 属性,最后都会生成一个对应的 watcher 对象,但是这类 watcher 有个特点:当计算属性依赖于其他数据时,属性并不会立即重新计算

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!