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 是一個表達(dá)式,表示對象或原始值
以下是一些常見類型的返回結(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ù)和浮點(diǎn)數(shù)是同樣的儲存方法,所以1和1.0為同一個值.
Number.isSafeInteger()
JavaScript能夠準(zhǔn)確表示的整數(shù)范圍在-2^53到2^53之間(不含兩個端點(diǎn)),超過這個范圍,無法精確表示這個值。
總結(jié)
目前接觸到的一些方法,如果有新的日后再更新。感興趣的朋友們可以繼續(xù)關(guān)注腳本之家,好了,以上就是這篇文章的全部內(nèi)容了,希望對大家的學(xué)習(xí)或者工作能帶來一定的幫助。
相關(guān)文章
Js 代碼中,ajax請求地址后加隨機(jī)數(shù)防止瀏覽器緩存的原因
Js 代碼中,ajax請求地址后加隨機(jī)數(shù)防止瀏覽器緩存的原因,需要的朋友可以參考一下2013-05-05
移動端點(diǎn)擊圖片放大特效PhotoSwipe.js插件實現(xiàn)
這篇文章主要為大家詳細(xì)介紹了移動端點(diǎn)擊圖片放大特效PhotoSwipe.js插件實現(xiàn)方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-08-08
javascript判斷網(wǎng)頁是關(guān)閉還是刷新
本篇文章給大家介紹js判斷網(wǎng)頁是關(guān)閉還是刷新,實現(xiàn)原理就是通過離開頁面行為時間onunload觸發(fā)時間去檢測此時的瀏覽器的窗口大小,根據(jù)大小由此判斷用戶是刷新,跳轉(zhuǎn)或是關(guān)閉行為程序,需要的朋友可以參考下本文2015-09-09

