Javascript中常用的檢測方法小結(jié)
一、數(shù)組檢測
1.使用ARRAY.ISARRAY()
Array.isArray(obj)
例如:
Array.isArray([]) //true Array.isArray({}) //false
兼容性:
CHROME | FIREFOX | IE | OPERA | SAFARI |
5 | 4.0(2.0) | 9 | 10.5 | 5 |
可以使用以下方式,先檢測是否支持Array.isArray
。
if(Array.isArray){ return Array.isArray(obj); }
2. 使用INSTANCEOF
arr instanceof Array
例如:
var arr=[]; console.log(arr instanceof Array); //true
3. 使用OBJECT.PROTOTYPE.TOSTRING方法
if( Object.prototype.toString.call(arr) === '[object Array]' ) { console.log("yes"); }
4.使用CONSTRUCTOR的方法
function isArray(obj){ return !!obj && Array === obj.constructor; }
二、類型檢測
typeof操作符檢測給定變量的數(shù)據(jù)類型
typeof operand //operand 是一個表達式,表示對象或原始值
以下是一些常見類型的返回結(jié)果,值得注意的是null返回的是object,其實對于引用類型的判斷都為object。
TYPE | RESULT |
Undefined | “undefined” |
Null | “object” (see below) |
Boolean | “boolean” |
Number | “number” |
String | “string” |
Symbol (new in ECMAScript 2015) | “symbol” |
Host object (provided by the JS environment) | Implementation-dependent |
Function object (implements [[Call]] in ECMA-262 terms) | “function” |
Any other object | “object” |
三、對象類型檢測
1. INSTANCEOF
用來檢測 constructor.prototype
是否存在于object 的原型鏈上
使用方式:
object instanceof constructor
舉個例子:
function A(){}; var a=new A(); a instanceof A //true a instanceof Object //true a.prototype instanceof Object //true
2. ISPROTOTYPEOF
只要是原型鏈所派生的實例的原型,會返回true
Object.prototype.isPrototypeOf(instance);
這里需要注意的是與instanceof的區(qū)別,在constructors被復(fù)寫,而又沒有重新制定的情況下,照樣可以使用isPrototype
var A = { //something } var B = Object.create(A); var C = Object.create(B); console.log(A.isPrototypeOf(C)); // true console.log(C instanceof A); //TypeError
3. HASOWNPROPERTY
hasOwnProperty()
方法用來判斷某個對象是否含有指定的自身屬性。
4. OBJECT.IS()
用來比較兩個值是否嚴(yán)格相等,與===相同
四、基本類型檢測
NUMBER
Number.isFinite()
用來檢查一個數(shù)值是否為有限的(finite)
Number.isNaN()
用來檢查一個值是否為NaN
Number.isInteger()
用來判斷一個值是否為整數(shù)。在JavaScript中,整數(shù)和浮點數(shù)是同樣的儲存方法,所以1和1.0為同一個值.
Number.isSafeInteger()
JavaScript能夠準(zhǔn)確表示的整數(shù)范圍在-2^53到2^53之間(不含兩個端點),超過這個范圍,無法精確表示這個值。
總結(jié)
目前接觸到的一些方法,如果有新的日后再更新。感興趣的朋友們可以繼續(xù)關(guān)注腳本之家,好了,以上就是這篇文章的全部內(nèi)容了,希望對大家的學(xué)習(xí)或者工作能帶來一定的幫助。
相關(guān)文章
JavaScript 函數(shù)參數(shù)是傳值(byVal)還是傳址(byRef) 分享
這篇文章主要介紹了在JS中函數(shù)參數(shù)是傳值(byVal)還是傳址(byRef)的誤區(qū)我們通過實例說明一下,有需要的朋友可以參考2013-07-07javascript實現(xiàn)鎖定網(wǎng)頁、密碼解鎖效果(類似系統(tǒng)屏幕保護效果)
這篇文章主要介紹了javascript實現(xiàn)鎖定網(wǎng)頁、密碼解鎖效果,跟Windows系統(tǒng)的屏幕保護效果類似,需要的朋友可以參考下2014-08-08Postman如何實現(xiàn)參數(shù)化執(zhí)行及斷言處理
這篇文章主要介紹了Postman如何實現(xiàn)參數(shù)化執(zhí)行及斷言處理,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-07-07JavaScript折半查找(二分查找)算法原理與實現(xiàn)方法示例
這篇文章主要介紹了JavaScript折半查找(二分查找)算法原理與實現(xiàn)方法,結(jié)合具體問題描述了折半查找算法的原理、實現(xiàn)方法及相關(guān)操作注意事項,需要的朋友可以參考下2018-08-08