詳解js的六大數(shù)據(jù)類型[轉載]

js中有六種數(shù)據(jù)類型幅骄,包括五種基本數(shù)據(jù)類型(Number,String,Boolean,Null,Undefined),和一種混合數(shù)據(jù)類型(Object)匪蟀。

js中變量是松散類型的湃窍,因此有時候我們需要檢測變量的數(shù)據(jù)類型。
typeof操作符可以檢測變量的數(shù)據(jù)類型(輸出的是一個關于數(shù)據(jù)類型的字符串)匪傍。
返回如下6種字符串:number,string,boolean,object,undefined,function.且看如下例子:
var x = 1;
console.log(typeof x);//number

var a = undefined;
console.log(typeof a);//undefined

var b = null;
console.log(typeof b);//object您市,(null是空對象引用/或者說指針)。

var c = new Object();
console.log(typeof c);//object

var e = [1,2,3];
console.log(typeof e);//object

var d = function(){
// ... 語句塊
}
console.log(typeof d);//function
上面代碼中役衡,null類型進行typeof操作符后茵休,結果是object,原因在于手蝎,null類型被當做一個空對象引用榕莺。
下面開始針對每一種數(shù)據(jù)類型單個講解:
1.Number類型
Number類型包含整數(shù)和浮點數(shù)(浮點數(shù)數(shù)值必須包含一個小數(shù)點,且小數(shù)點后面至少有一位數(shù)字)兩種值棵介。
浮點數(shù)將會自動轉換為整數(shù)钉鸯。
var num = 1.00;
console.log(num);//1,自動轉換為整數(shù)
浮點數(shù)的最高精度是17位邮辽,看下面的例子唠雕,結果竟然不是0.3,至于其他編程語言吨述,也會遇到這種情況(關于浮點數(shù)計算會產(chǎn)生舍入誤差問題岩睁,其他有些編程語言也會出現(xiàn)類似情況。)
var num1 = 0.1;
var num2 = 0.2;
console.log(num1 + num2);//0.30000000000000004
NaN:非數(shù)字類型揣云。特點:① 涉及到的 任何關于NaN的操作捕儒,都會返回NaN ② NaN不等于自身。
var ab = "a1";
console.log(ab/10);// NaN
console.log(NaN == NaN);// false;
isNaN()函數(shù)邓夕,用于判斷是否是一個非數(shù)字類型刘莹。如果傳入的參數(shù)是一個非數(shù)字類型,那么返回true焚刚;否則返回false;
isNaN()函數(shù)栋猖,傳入一個參數(shù),函數(shù)會先將參數(shù)轉換為數(shù)值汪榔。
如果參數(shù)類型為對象類型,會先調用對象的valueOf()方法肃拜, 再確定該方法返回的值是否可以轉換為數(shù)值類型痴腌。如果不能,再調用對象的toString()方法燃领,再確定返回值士聪。
數(shù)值轉換:
Number()轉型函數(shù),可以用于任何數(shù)據(jù)類型猛蔽;
parseInt()剥悟,將值轉換為整型灵寺,用的比較多;
parseFloat()区岗;將值轉換為浮點型略板。
2.String類型
字符串類型中的單引號與雙引號的作用效果完全一樣。
字符串有l(wèi)ength屬性慈缔《3疲可以取得字符串的長度。var str = “hello”;console.log(str.length);//5
字符串的值是不可變的藐鹤。要改變一個字符串的值瓤檐,首先要銷毀原來的字符串,再用另一個包含新值的字符串去填充該字符串娱节。
var lang = “java”;
lang += “script”;
上面這段代碼挠蛉,先創(chuàng)建一個能容納10個字符的字符串,然后在這個字符串中填充java和script字符串肄满,最后銷毀原來的字符串java和scrip字符串谴古,因為這兩個字符串此時已經(jīng)沒用了。這個個過程是在后臺發(fā)生的悄窃。
字符串轉換:轉型函數(shù)String(),適用于任何數(shù)據(jù)類型(null,undefined 轉換后為null和undefined)讥电;toString()方法(null,defined沒有toString()方法)。
var bc = "lijinwen";
var bd = null;
var be = undefined;
console.log(bc.toString());
//console.log(bd.toString());//error 報錯
//console.log(be.toString());//error 報錯
console.log("------");
console.log(String(bc));
console.log(String(bd));
console.log(String(be));
3.Boolean類型
該類型只有兩個值轧抗,true和false
轉換為boolean值: 轉型函數(shù)Boolean(),將某個值轉換為Boolean類型恩敌。詳細內容,后面會慢慢的補充横媚。
4.Null類型
null類型被看做空對象指針纠炮,前文說到null類型也是空的對象引用。只有一個值灯蝴,即null值恢口,所以,在你 用typeof 操作符去檢測null類型的值時穷躁,結果是object類型耕肩。
如果你定義了一個變量,但是想在以后把這個變量當做一個對象來用问潭,那么最好將該對象初始化為null值猿诸。
5.Undefined類型
只有一個值,即undefined值狡忙。使用var聲明了變量梳虽,但未給變量初始化值,那么這個變量的值就是undefined灾茁。
var name = "lijinwen";
var age;
console.log(name);//lijinwen
console.log(age);//undefined
//console.log(height);//error窜觉,變量height沒有聲明
console.log(typeof name);//string
console.log(typeof age);//undefined
console.log(typeof height);//undefined谷炸,變量height沒有聲明
上面這段代碼中,age雖然聲明了禀挫,但是沒有初始化值旬陡,所以,打印出來的是undefined.而變量height沒有聲明特咆,故報錯季惩。
但是用typeof操作符去檢測數(shù)據(jù)類型的時候,變量age沒有初始化腻格,結果是undefined画拾,沒有聲明變量的height檢測的類型也是undefined.
6.Object類型
js中對象是一組屬性與方法的集合菜职。具體的關于對象的創(chuàng)建方式以及對象的各種特性青抛,會在后面的引用類型的章節(jié)中 做詳細介紹。這里就簡單介紹一下六大數(shù)據(jù)類型中的Object.
①constructor屬性:構造函數(shù)屬性,可確定當前對象的構造函數(shù)酬核。
var o = new Object();
console.log(o.constructor == Object);//true
var arr = new Array();
console.log(arr.constructor == Array);//true
②hasOwnProperty(propertyName):判斷屬性是否存在于當前對象實例中(而不是原型對象中)蜜另。這個在后面的面向對象的章節(jié)中 有詳細的講解。
③…更多關于Object請查看后面的章節(jié)面向對象嫡意。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末举瑰,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蔬螟,更是在濱河造成了極大的恐慌此迅,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,639評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件旧巾,死亡現(xiàn)場離奇詭異耸序,居然都是意外死亡,警方通過查閱死者的電腦和手機鲁猩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評論 3 385
  • 文/潘曉璐 我一進店門坎怪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人廓握,你說我怎么就攤上這事搅窿。” “怎么了隙券?”我有些...
    開封第一講書人閱讀 157,221評論 0 348
  • 文/不壞的土叔 我叫張陵男应,是天一觀的道長。 經(jīng)常有香客問我是尔,道長,這世上最難降的妖魔是什么开仰? 我笑而不...
    開封第一講書人閱讀 56,474評論 1 283
  • 正文 為了忘掉前任拟枚,我火速辦了婚禮薪铜,結果婚禮上,老公的妹妹穿的比我還像新娘恩溅。我一直安慰自己隔箍,他們只是感情好,可當我...
    茶點故事閱讀 65,570評論 6 386
  • 文/花漫 我一把揭開白布脚乡。 她就那樣靜靜地躺著蜒滩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪奶稠。 梳的紋絲不亂的頭發(fā)上俯艰,一...
    開封第一講書人閱讀 49,816評論 1 290
  • 那天,我揣著相機與錄音锌订,去河邊找鬼竹握。 笑死,一個胖子當著我的面吹牛辆飘,可吹牛的內容都是我干的啦辐。 我是一名探鬼主播,決...
    沈念sama閱讀 38,957評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼蜈项,長吁一口氣:“原來是場噩夢啊……” “哼芹关!你這毒婦竟也來了?” 一聲冷哼從身側響起紧卒,我...
    開封第一講書人閱讀 37,718評論 0 266
  • 序言:老撾萬榮一對情侶失蹤侥衬,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后常侦,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體浇冰,經(jīng)...
    沈念sama閱讀 44,176評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,511評論 2 327
  • 正文 我和宋清朗相戀三年聋亡,在試婚紗的時候發(fā)現(xiàn)自己被綠了肘习。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,646評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡坡倔,死狀恐怖漂佩,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情罪塔,我是刑警寧澤投蝉,帶...
    沈念sama閱讀 34,322評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站征堪,受9級特大地震影響瘩缆,放射性物質發(fā)生泄漏。R本人自食惡果不足惜佃蚜,卻給世界環(huán)境...
    茶點故事閱讀 39,934評論 3 313
  • 文/蒙蒙 一庸娱、第九天 我趴在偏房一處隱蔽的房頂上張望着绊。 院中可真熱鬧,春花似錦熟尉、人聲如沸归露。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽剧包。三九已至,卻和暖如春往果,著一層夾襖步出監(jiān)牢的瞬間疆液,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評論 1 266
  • 我被黑心中介騙來泰國打工棚放, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留枚粘,地道東北人。 一個月前我還...
    沈念sama閱讀 46,358評論 2 360
  • 正文 我出身青樓飘蚯,卻偏偏與公主長得像馍迄,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子局骤,可洞房花燭夜當晚...
    茶點故事閱讀 43,514評論 2 348

推薦閱讀更多精彩內容