首頁 > web前端 > js教程 > 主體

JavaScript中typeof和instanceof的比較用法實例詳解

伊谢尔伦
發布: 2017-07-22 15:41:47
原創
1621 人瀏覽過

typeof

先來說說typeof吧。首先要注意的是,typeof方法傳回一個字串,來表示資料的型別。

typeof 是一個一元運算,放在一個運算數之前,運算數可以是任意型別。

它傳回值是一個字串,該字串說明運算數的類型。 typeof 一般只能回傳以下幾個結果:
number,boolean,string,function,object,undefined。我們可以使用typeof 來取得一個變數是否存在,如if(typeof a!="undefined"){alert("ok")},而不要去使用if(a) 因為如果a 不存在(未宣告)則會出錯,對於Array,Null 等特殊物件使用typeof 一律傳回object,這正是typeof 的限制。

語法講解

我們先看看各個資料型態對應typeof的值:

typeof 37 === 'number';
typeof 3.14 === 'number';
typeof Math.LN2 === 'number';
typeof Infinity === 'number';
typeof NaN === 'number'; // 尽管NaN是"Not-A-Number"的缩写,意思是"不是一个数字"
typeof Number(1) === 'number'; // 不要这样使用!
// Strings
typeof "" === 'string';
typeof "bla" === 'string';
typeof (typeof 1) === 'string'; // typeof返回的肯定是一个字符串
typeof String("abc") === 'string'; // 不要这样使用!
// Booleans
typeof true === 'boolean';
typeof false === 'boolean';
typeof Boolean(true) === 'boolean'; // 不要这样使用!
// Symbols
typeof Symbol() === 'symbol';
typeof Symbol('foo') === 'symbol';
typeof Symbol.iterator === 'symbol';
// Undefined
typeof undefined === 'undefined';
typeof blabla === 'undefined'; // 一个未定义的变量,或者一个定义了却未赋初值的变量
// Objects
typeof {a:1} === 'object';
// 使用Array.isArray或者Object.prototype.toString.call方法可以从基本的对象中区分出数组类型
typeof [1, 2, 4] === 'object';
typeof new Date() === 'object';
// 下面的容易令人迷惑,不要这样使用!
typeof new Boolean(true) === 'object';
typeof new Number(1) ==== 'object';
typeof new String("abc") === 'object';
// 函数
typeof function(){} === 'function';
typeof Math.sin === 'function';
登入後複製

我們會發現一個問題,就是typeof來判斷資料型別其實並不準確。例如數組、正規、日期、物件的typeof回傳值都是object,這就會造成一些誤差。

所以在typeof判斷類型的基礎上,我們還需要利用Object.prototype.toString方法來進一步判斷資料型別。

我們來看看在相同資料型別的情況下,toString方法和typeof方法傳回值的差異:

“foo”objectnew Number( 1.2)Numberobjecttru​​eBooleanboolean

可以看到利用toString方法可以正确区分出Array、Error、RegExp、Date等类型。

所以我们一般通过该方法来进行数据类型的验证

instanceof

接下来该说说instanceof方法了。instanceof运算符可以用来判断某个构造函数的prototype属性是否存在于另外一个要检测对象的原型链上。

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) 会返回

谈到 instanceof 我们要多插入一个问题,就是 function 的 arguments,我们大家也许都认为 arguments 是一个 Array,但如果使用 instaceof 去测试会发现 arguments 不是一个 Array 对象,尽管看起来很像。

如果对原型不太了解,可以看看深入理解原型。

下面我们看看instanceof的实例:

// 定义构造函数
function C(){} 
function D(){} 
var o = new C();
// true,因为 Object.getPrototypeOf(o) === C.prototype
o instanceof C; 
// false,因为 D.prototype不在o的原型链上
o instanceof D; 
o instanceof Object; // true,因为Object.prototype.isPrototypeOf(o)返回true
C.prototype instanceof Object // true,同上
C.prototype = {};
var o2 = new C();
o2 instanceof C; // true
o instanceof C; // false,C.prototype指向了一个空对象,这个空对象不在o的原型链上.
D.prototype = new C(); // 继承
var o3 = new D();
o3 instanceof D; // true
o3 instanceof C; // true
登入後複製

但是这里我们需要注意一个问题:

function f(){ return f; }
document.write(new f() instanceof f);//false
function g(){}
document.write(new g() instanceof g);//true
登入後複製

第一个为什么返回false呢?因为构造函数的原型被覆盖了。


以上是JavaScript中typeof和instanceof的比較用法實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
資料toStringtypeof
“foo”String
new Boolean(true)Booleanobject
new Date()Date
新數組(1, 2, 3)Arrayobject
/abc/gRegExpobject