亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

js中typeof與instanceof的區別

標簽:
JavaScript

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) 

会返回true。

谈到 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。



另外,用instanceof可以判断变量是否为数组有几种方法可以拿来判断:


(1)、constructor属性


这个属性在我们使用js系统或者自己创建的对象的时候,会默认的加上,例如:


var arr = [1,2,3];  //创建一个数组对象

arr.prototype.constructor = Array;  //这一句是系统默认加上的

所以我们就可以这样来判断:


var arr = [1,2,3,1]; 

alert(arr.constructor === Array);   // true

(2)、instanceof


instanceof是检测对象的原型链是否指向构造函数的prototype对象的,所以我们也可以用它来判断:


var arr = [1,2,3]; 

alert(arr instanceof Array);   // true

最后,为了给大家一个结果,现写出一个终极解决方案:


判断数组终极解决方案


var arr = [1,2,3]; 

function isArrayFn(obj){  //封装一个函数

  if (typeof Array.isArray === "function") { 

    return Array.isArray(obj); //浏览器支持则使用isArray()方法

  }else{  //否则使用toString方法

    return Object.prototype.toString.call(obj) === "[object Array]"; 

  } 

alert(isArrayFn(arr));// true

摘自:

https://www.cnblogs.com/pengyawn/p/6272890.html

https://blog.csdn.net/qq_27626333/article/details/76146078 


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
Web前端工程師
手記
粉絲
6
獲贊與收藏
44

關注作者,訂閱最新文章

閱讀免費教程

  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消