DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Javascript中常用的檢測方法小結
Javascript中常用的檢測方法小結
編輯:關於JavaScript     

一、數組檢測

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操作符檢測給定變量的數據類型

typeof operand //operand 是一個表達式,表示對象或原始值

以下是一些常見類型的返回結果,值得注意的是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的區別,在constructors被復寫,而又沒有重新制定的情況下,照樣可以使用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()

用來比較兩個值是否嚴格相等,與===相同

四、基本類型檢測

NUMBER

Number.isFinite()

用來檢查一個數值是否為有限的(finite)

Number.isNaN()

用來檢查一個值是否為NaN

Number.isInteger()

用來判斷一個值是否為整數。在JavaScript中,整數和浮點數是同樣的儲存方法,所以1和1.0為同一個值.

Number.isSafeInteger()

JavaScript能夠准確表示的整數范圍在-2^53到2^53之間(不含兩個端點),超過這個范圍,無法精確表示這個值。

總結

目前接觸到的一些方法,如果有新的日後再更新。感興趣的朋友們可以繼續關注,好了,以上就是這篇文章的全部內容了,希望對大家的學習或者工作能帶來一定的幫助。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved