javascript基本類(lèi)型詳解
js中一共5個(gè)原始值,6個(gè)typeof能判斷的,9個(gè)原生的內(nèi)置的構(gòu)造函數(shù)。
這569,構(gòu)成了js語(yǔ)言的基礎(chǔ)。
5個(gè)原始值是:數(shù)字,字符,布爾,null,undefined
typeof能判斷:數(shù)字,字符,布爾,object,function,undefined。 注意null和數(shù)組,tyopeof都輸出object。
typeof不能區(qū)分出數(shù)組和對(duì)象,如何判斷類(lèi)型呢?使用Object.prototype.toString.apply()。
if(value&&typeof value ==='object'&&value.constructor === Array)
上面的檢測(cè)如果在不同幀和窗口創(chuàng)建的數(shù)組,會(huì)給出false,window對(duì)象不一樣了.
可靠的方法是if(Object.prototype.toString.apply(value)==="[object Array]")
arguments 數(shù)組不是一個(gè)數(shù)組,他只是一個(gè)有著length成員屬性的對(duì)象。
如下面例子所示 arguments不是普通的array
var a = function (){
var b = Object.prototype.toString.apply(arguments);
console.log(b);
}
a();//輸出[object Arguments]
var a = function (){
var c = [];
var b = Object.prototype.toString.apply(c);
console.log(b);
}
a();//輸出[object Array]
instanceof是如何判斷是否實(shí)例
prototype里面的屬性有constructor.
默認(rèn)的prototype屬性是一個(gè)object對(duì)象,可以設(shè)置為任何復(fù)雜值,忽略設(shè)置為原始值.
雖然他盡是一個(gè)對(duì)象,但他是特殊性的,圓形鏈將每個(gè)實(shí)例都鏈接至其構(gòu)造函數(shù)的prototype屬性。實(shí)例與構(gòu)造函數(shù)的 prototype屬性之間有一個(gè)隱蔽的鏈接,這就是實(shí)例的__proto__。同時(shí)實(shí)例的constructor屬性是通過(guò)構(gòu)造函數(shù)prototype的constructor拿到的。
但是要保留constructor,這樣可以讓new的實(shí)例有constructor的屬性,也可以使用instanceof來(lái)判斷。
var Foo = function(){}
Foo.prototype={constructor:Foo}
var FooInstance = new Foo;
FooInstance.__proto__=== Foo.prototype;//true
FooInstance.constructor === Foo; //true
實(shí)際上instanceof判斷不是依據(jù)constructor,而是依據(jù)原型鏈判斷,如下面例子
var Foo = function(){};
Foo.prototype={};
var FooInstance = {};
FooInstance.__proto__=Foo.prototype;
console.log(FooInstance instanceof Foo);//true
使用原始值,不使用構(gòu)造函數(shù)
哪些值算是false:false,"",null,0,-0,NaN,undefined,這些算是false其他都是true
但是請(qǐng)注意下面這個(gè)例子
var a = Boolean(false);
var b = new Boolean("");
if (a ){console.log(a);}//無(wú)法輸出
if (b ){console.log(b);}//Boolean {[[PrimitiveValue]]: false} new 一個(gè)相當(dāng)于一個(gè)對(duì)象了,就不是false
上面的文章理論性稍強(qiáng)了一些,不過(guò)這些都是構(gòu)成javascript語(yǔ)言的基礎(chǔ),一定要了解清楚才行。
- Ext對(duì)基本類(lèi)型的擴(kuò)展 ext,extjs,format
- JavaScript中“基本類(lèi)型”之爭(zhēng)小結(jié)
- javascript面向?qū)ο蟀b類(lèi)Class封裝類(lèi)庫(kù)剖析
- 淺析JavaScript基本類(lèi)型與引用類(lèi)型
- JavaScript數(shù)據(jù)類(lèi)型之基本類(lèi)型和引用類(lèi)型的值
- Javascript中的包裝類(lèi)型介紹
- javascript基本包裝類(lèi)型介紹
- 淺談javascript中基本包裝類(lèi)型
- JavaScript類(lèi)型系統(tǒng)之基本數(shù)據(jù)類(lèi)型與包裝類(lèi)型
相關(guān)文章
JavaScript實(shí)現(xiàn)快速排序(自已編寫(xiě))
用到j(luò)avascript的排序一組數(shù)字,js沒(méi)有直接的數(shù)字比較的函數(shù)可以調(diào)用,所以自己寫(xiě)了一個(gè)快速排序,需要的朋友可以了解下2012-12-12JavaScript運(yùn)行時(shí)庫(kù)屬性一覽表
這篇文章主要介紹了JavaScript運(yùn)行時(shí)庫(kù)屬性,需要的朋友可以參考下2014-03-03Javascript入門(mén)學(xué)習(xí)第四篇 js對(duì)象和數(shù)組
上篇文章講了js中的變量,表達(dá)式,和運(yùn)算符 還有一些 js 語(yǔ)句. 這章我們來(lái)探討js中的對(duì)象和數(shù)組。2008-07-07JavaScript必知必會(huì)(七)js對(duì)象繼承
這篇文章主要介紹了JavaScript必知必會(huì)(七)js對(duì)象繼承的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06在Javascript中 聲明時(shí)用"var"與不用"var"的區(qū)別
Javascript聲明變量的時(shí)候,雖然用var關(guān)鍵字聲明和不用關(guān)鍵字聲明,很多時(shí)候運(yùn)行并沒(méi)有問(wèn)題,但是這兩種方式還是有區(qū)別的2013-04-04JavaScript入門(mén)教程(2) JS基礎(chǔ)知識(shí)
JavaScript 可以出現(xiàn)在 HTML 的任意地方。使用標(biāo)記<script>…</script>,你可以在 HTML 文檔的任意地方插入 JavaScript,甚至在<HTML>之前插入也不成問(wèn)題。2009-01-01