摘要:中的數(shù)據(jù)類型及其檢測(cè)數(shù)據(jù)類型基本類型引用類型類型檢測(cè)只能檢測(cè)基本數(shù)據(jù)類型,對(duì)于還有一個(gè)用于檢測(cè)某個(gè)對(duì)象的原型鏈?zhǔn)欠癜硞€(gè)構(gòu)造函數(shù)的屬性適用于檢測(cè)對(duì)象,它是基于原型鏈運(yùn)作的屬性返回一個(gè)指向創(chuàng)建了該對(duì)象原型的函數(shù)引用,該屬性的值是哪個(gè)函數(shù)本身
JavaScript中的數(shù)據(jù)類型及其檢測(cè) 1. 數(shù)據(jù)類型 1.1 基本類型
Number
String
Boolean
Null
Undefined
Symbol
1.2 引用類型Object
Array
Function
RegExp
Date
2. 類型檢測(cè) 2.1 typeofvar s = "Nicholas"; var b = true; var i = 22; var u; var n = null; var o = new Object(); var f = new Function(); console.info(typeof s); // string console.info(typeof b); // boolean console.info(typeof i); // number console.info(typeof u); // undefined console.info(typeof n); // object console.info(typeof o); // object console.info(typeof f); // function
typeof只能檢測(cè)基本數(shù)據(jù)類型,對(duì)于null還有一個(gè)Bug
2.2 instanceofresult = variable instanceof constructor
instanceof用于檢測(cè)某個(gè)對(duì)象的原型鏈?zhǔn)欠癜硞€(gè)構(gòu)造函數(shù)的prototype屬性
function C() {} function D() {} var o = new C(); o instanceof C // true, Object.getPrototypeOf(o) === C.prototype o instanceof D // false function Animal() {} function Cat() {} Cat.prototype = new Animal(); var b = new Cat(); b instanceof Animal // true [1, 2, 3] instanceof Array // true /abc/ instanceof RegExp // true ({}) instanceof Object // true (function() {}) instanceof Function // true
instanceof適用于檢測(cè)對(duì)象,它是基于原型鏈運(yùn)作的
2.3 constructorconstructor屬性返回一個(gè)指向創(chuàng)建了該對(duì)象原型的函數(shù)引用,該屬性的值是哪個(gè)函數(shù)本身。
function Animal() {} function Cat() {} function BadCat() {} Cat.prototype = new Animal(); BadCat.prototype = new Cat(); var a = new Animal(); a.constructor === Animal // true var b = new BadCat(); b.constructor === Animal // true
constructor指向的是最初創(chuàng)建者,而且易于偽造,不適合做類型判斷
2.4 toStringObject.prototype.toString.call(); ({}).toString.call(); window.toString.call(); toString.call();
Object.prototype.toString.call([]); // [object Array] Object.prototype.toString.call({}); // [object Object] Object.prototype.toString.call(""); // [object String] Object.prototype.toString.call(new Date()); // [object Date] Object.prototype.toString.call(1); // [object Number] Object.prototype.toString.call(function () {}); // [object Function] Object.prototype.toString.call(/test/i); // [object RegExp] Object.prototype.toString.call(true); // [object Boolean] Object.prototype.toString.call(null); // [object Null] Object.prototype.toString.call(); // [object Undefined]
幾乎十全十美,只是不能檢測(cè)用戶自定義類型
2.5 小結(jié)typeof只能檢測(cè)基本數(shù)據(jù)類型,對(duì)于null還有Bug
instanceof適用于檢測(cè)對(duì)象,它是基于原型鏈運(yùn)作的
constructor指向的是最初創(chuàng)建者,而且容易偽造,不適合做類型判斷
toString適用于ECMA內(nèi)置JavaScript類型(包括基本數(shù)據(jù)類型和內(nèi)置對(duì)象)的類型判斷
基于引用判等的類型檢查都有跨窗口問題,比如instanceof和constructor
如果你要判斷的是基本數(shù)據(jù)類型或JavaScript內(nèi)置對(duì)象,使用toString;如果要判斷的是自定義類型,請(qǐng)使用instanceof
參考w3cPlus - JavaScrit的變量:如何檢測(cè)變量類型
JavaScript高級(jí)程序設(shè)計(jì)(第3版)
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/90905.html
摘要:值的比較只進(jìn)行值的比較會(huì)進(jìn)行數(shù)據(jù)類型的轉(zhuǎn)換。只要在當(dāng)前實(shí)例的原型鏈上,我們用其檢測(cè)出來(lái)的結(jié)果都是。但檢測(cè)與不一樣,還可以處理基本數(shù)據(jù)類型的檢測(cè)。 showImg(https://segmentfault.com/img/remote/1460000016733921); 一、JavaScript有幾種類型的值? Javascript有兩種數(shù)據(jù)類型,分別是基本數(shù)據(jù)類型和引用數(shù)據(jù)類型。其中...
摘要:值的比較只進(jìn)行值的比較會(huì)進(jìn)行數(shù)據(jù)類型的轉(zhuǎn)換。只要在當(dāng)前實(shí)例的原型鏈上,我們用其檢測(cè)出來(lái)的結(jié)果都是。但檢測(cè)與不一樣,還可以處理基本數(shù)據(jù)類型的檢測(cè)。 showImg(https://segmentfault.com/img/remote/1460000016733921); 一、JavaScript有幾種類型的值? Javascript有兩種數(shù)據(jù)類型,分別是基本數(shù)據(jù)類型和引用數(shù)據(jù)類型。其中...
摘要:值的比較只進(jìn)行值的比較會(huì)進(jìn)行數(shù)據(jù)類型的轉(zhuǎn)換。只要在當(dāng)前實(shí)例的原型鏈上,我們用其檢測(cè)出來(lái)的結(jié)果都是。但檢測(cè)與不一樣,還可以處理基本數(shù)據(jù)類型的檢測(cè)。 showImg(https://segmentfault.com/img/remote/1460000016733921); 一、JavaScript有幾種類型的值? Javascript有兩種數(shù)據(jù)類型,分別是基本數(shù)據(jù)類型和引用數(shù)據(jù)類型。其中...
摘要:之關(guān)鍵字保留字變量及數(shù)據(jù)類型個(gè)人總結(jié),分享也供自己日后查詢變量中變量通過關(guān)鍵字來(lái)聲明的。在使用聲明變量但未對(duì)其加以初始化時(shí),這個(gè)變量的值就是,例如在控制臺(tái)輸出是也就是未定義類型布爾類型該類型只有兩個(gè)字面值和。 javascript之關(guān)鍵字,保留字, 變量及數(shù)據(jù)類型 個(gè)人總結(jié),分享也供自己日后查詢 1.變量 javascript 中變量通過var關(guān)鍵字(variable)來(lái)聲明的。 變量...
閱讀 3295·2021-11-25 09:43
閱讀 2097·2021-09-22 10:02
閱讀 3356·2021-09-06 15:00
閱讀 2308·2019-08-30 15:56
閱讀 2361·2019-08-30 15:54
閱讀 3237·2019-08-30 14:14
閱讀 2270·2019-08-29 17:25
閱讀 2913·2019-08-29 17:16