[JS中的數(shù)據(jù)類型]
js中有五種基本數(shù)據(jù)類型(Number,String,Boolean,Undefined,Null),和一種復雜數(shù)據(jù)類型(Object)笤妙。
typeof 操作符
由于js
中的變量是松散類型的唯咬,所以它提供了一種檢測當前變量的數(shù)據(jù)類型的方法,也就是typeof關(guān)鍵字.
typeof 123 //Number
typeof 'abc' //String
typeof true //Boolean
typeof undefined //Undefined
typeof null //Object
typeof { } //Object
typeof [ ] //Object
typeof console.log() //Function
null類型進行typeof操作符后,結(jié)果是object财破,原因在于,null類型被當做一個空對象引用。
1.Number類型
Number類型包含整數(shù)和浮點數(shù)(浮點數(shù)數(shù)值必須包含一個小數(shù)點窝撵,且小數(shù)點后面至少有一位數(shù)字)兩種值。
NaN:非數(shù)字類型襟铭。特點:① 涉及到的 任何關(guān)于NaN的操作碌奉,都會返回NaN ② NaN不等于自身。
isNaN() 函數(shù)用于檢查其參數(shù)是否是非數(shù)字值寒砖。
isNaN(123) //false isNaN("hello") //true
2.String類型
字符串有l(wèi)ength屬性赐劣。
字符串轉(zhuǎn)換:轉(zhuǎn)型函數(shù)String(),適用于任何數(shù)據(jù)類型(null,undefined 轉(zhuǎn)換后為null和undefined);toString()方法(null,defined沒有toString()方法)哩都。
3.Boolean類型
該類型只有兩個值魁兼,true和false
4.Undefined類型
只有一個值,即undefined值漠嵌。使用var聲明了變量咐汞,但未給變量初始化值,那么這個變量的值就是undefined儒鹿。
5.Null類型
null類型被看做空對象指針化撕,前文說到null類型也是空的對象引用。
6.Object類型
js中對象是一組屬性與方法的集合约炎。這里就要說到引用類型了植阴,引用類型是一種數(shù)據(jù)結(jié)構(gòu),用于將數(shù)據(jù)和功能組織在一起圾浅。引用類型有時候也被稱為對象定義掠手,因為它們描述的是一類對象所具有的屬性和方法。
三大引用類型
1.Object類型
我們看到的大多數(shù)類型值都是Object類型的實例狸捕,創(chuàng)建Object實例的方式有兩種喷鸽。
第一種是使用new操作符后跟Object構(gòu)造函數(shù),如下所示
var person = new Object();
person.name = "Micheal";
person.age = 24;
第二種方式是使用對象字面量表示法府寒,如下所示
var person = {
name : "Micheal",
age : 24
};
2.Array類型
數(shù)組的每一項可以用來保存任何類型的數(shù)據(jù)魁衙,也就是說报腔,可以用數(shù)組的第一個位置來保存字符串,第二個位置保存數(shù)值剖淀,第三個位置保存對象....另外纯蛾,數(shù)組的大小是可以動態(tài)調(diào)整的。
創(chuàng)建數(shù)組的基本方式有兩種
第一種是使用Array構(gòu)造函數(shù)纵隔,如下所示
var colors = new Array("red","blue","yellow");
第二種是使用數(shù)組字面量表示法翻诉,如下所示
var colors = ["red","blue","yellow"];
3 Function類型
每個函數(shù)都是Function類型的實例,而且都與其他引用類型一樣具有屬性和方法捌刮。函數(shù)通常是使用函數(shù)聲明語法定義的碰煌,如下所示
function sum(num1,num2){
return num1 + num2;
};
這和使用函數(shù)表達式定義函數(shù)的方式相差無幾。
var sun = function (){
return sum1 + sum2;
};
也就是說绅作,js按照存儲方式分為值類型和引用類型玷氏。那么他們的計算有什么區(qū)別呢锡足?
題目1: var a = 100;
var b = a;
a = 200;
console.log (b);
題目2: var a = {age : 20};
var b = a;
b.age = 21;
console.log (a.age);
題目1的答案是 100,題目2的答案是21,
題目1是簡單的值類型世落,在從一個變量向另一個變量賦值基本類型時狭瞎,會在該變量上創(chuàng)建一個新值匾乓,然后再把該值復制到為新變量分配的位置上懒震。
此時,a中保存的值為 100 岂贩,當使用 a 來初始化 b 時茫经,b 中保存的值也為100,但b中的100與a中的是完全獨立的萎津,該值只是a中的值的一個副本卸伞,此后,
這兩個變量可以參加任何操作而相互不受影響锉屈。也就是說基本類型在賦值操作后瞪慧,兩個變量是相互不受影響的。
題目2是引用類型部念,當從一個變量向另一個變量賦值引用類型的值時,同樣也會將存儲在變量中的對象的值復制一份放到為新變量分配的空間中氨菇。
這時保存在變量中的是對象在堆內(nèi)存中的地址儡炼,所以,與簡單賦值不同查蓉,這個值的副本實際上是一個指針乌询,而這個指針指向存儲在堆內(nèi)存的一個對象。那么賦值操作后豌研,
兩個變量都保存了同一個對象地址妹田,則這兩個變量指向了同一個對象唬党。因此,改變其中任何一個變量鬼佣,都會相互影響驶拱。
因此,引用類型的賦值其實是對象保存在棧區(qū)地址指針的賦值晶衷,因此兩個變量指向同一個對象蓝纲,任何的操作都會相互影響。