JavaScript instanceof 的使用方法有哪些
在 JavaScript 中,判斷一個(gè)變量的類型嘗嘗會用 typeof 運(yùn)算符,在使用 typeof 運(yùn)算符時(shí)采用引用類型存儲值會出現(xiàn)一個(gè)問題,無論引用的是什么類型的對象,它都返回 “object”。這就需要用到instanceof來檢測某個(gè)對象是不是另一個(gè)對象的實(shí)例。
通常來講,使用 instanceof 就是判斷一個(gè)實(shí)例是否屬于某種類型。
另外,更重的一點(diǎn)是 instanceof 可以在繼承關(guān)系中用來判斷一個(gè)實(shí)例是否屬于它的父類型。
復(fù)制代碼 代碼如下:
// 判斷 foo 是否是 Foo 類的實(shí)例 , 并且是否是其父類型的'實(shí)例function Aoo(){}
function Foo(){}
Foo.prototype = new Aoo();//JavaScript 原型繼承
var foo = new Foo();
console.log(foo instanceof Foo)//true
console.log(foo instanceof Aoo)//true
上面的代碼中是判斷了一層繼承關(guān)系中的父類,在多層繼承關(guān)系中,instanceof 運(yùn)算符同樣適用。
instanceof 復(fù)雜用法
復(fù)制代碼 代碼如下:
function Cat(){}
Cat.prototype = {}
function Dog(){}
Dog.prototype ={}
var dog1 = new Dog();
alert(dog1 instanceof Dog);//true
alert(dog1 instanceof Object);//true
Dog.prototype = Cat.prototype;
alert(dog1 instanceof Dog);//false
alert(dog1 instanceof Cat);//false
alert(dog1 instanceof Object);//true;
var dog2= new Dog();
alert(dog2 instanceof Dog);//true
alert(dog2 instanceof Cat);//true
alert(dog2 instanceof Object);//true
Dog.prototype = null;
var dog3 = new Dog();
alert(dog3 instanceof Cat);//false
alert(dog3 instanceof Object);//true
alert(dog3 instanceof Dog);//error
要想從根本上了解 instanceof 的奧秘,需要從兩個(gè)方面著手:1,語言規(guī)范中是如何定義這個(gè)運(yùn)算符的。2,JavaScript 原型繼承機(jī)。大家感興趣的可以去查看相關(guān)資料。
【JavaScript instanceof 的使用方法有哪些】相關(guān)文章:
1.關(guān)于JavaScript substring()的使用方法
6.關(guān)于JavaScript中的parse()的使用方法