欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript入門學(xué)習(xí)第二篇 js類型第1/2頁

 更新時間:2008年07月06日 09:58:09   作者:  
上篇文章講了js中的一些概念(詞法結(jié)構(gòu)) 和 數(shù)據(jù)類型(部分)。 這章我們 繼續(xù).然后了解下js中操作數(shù)據(jù) 和 函數(shù)的 作用域。
1,對象跟基本類型之間的轉(zhuǎn)換:
不管何時,只是對象非空,在布爾環(huán)境中都為true.
如;
new Boolean(false); 
new Number(0);
new String(“”);
new Array();
上面雖然內(nèi)部值是false,但對象的值是true;
Object ? valueOf() ? toString()
其中Date類,是先執(zhí)行toString()轉(zhuǎn)換。

2,js中操作一個數(shù)據(jù)值:
任何語言都有自己的操作數(shù)據(jù)的方法;
Js也不例外,js有3種重要的方式來操作一個數(shù)據(jù)值。
1)    復(fù)制它。例如把它賦給一個新的變量。
2)    把它作為參數(shù)傳遞給一個函數(shù)或方法。
3)    可以和其他值比較大小。

Js通過傳值和傳址2種方式操作這些數(shù)據(jù)的值。
從名稱可以看處,傳值 是通過傳遞值來操作數(shù)據(jù)。在賦值的過程中,對實(shí)際的值進(jìn)行了拷貝,存儲到一個新的變量中。拷貝的值和原來的值是2份完全獨(dú)立的值。所以如果你改變了拷貝的值,并不會影響原來的值。當(dāng)比較大小時候,通常進(jìn)行琢個字節(jié)比較。
傳址 從名字來看,就是通過傳遞地址來操作數(shù)據(jù)。在賦值的過程中,對實(shí)際的值的地址(可以說是引用)進(jìn)行了拷貝,他們不是完全的獨(dú)立,所以如果你通過引用改變了值,那么原始的值也會改變。當(dāng)比較大小的時候,通常是看他們是否引用同一個地址來比較。
簡單的傳址例子:
var a = new Date();
alert(a.getDate());
var b = a ;
b.setDate(21);
alert(a.getDate()) // 輸出21 

3,一般來說:
基本數(shù)據(jù)類型通過傳值來操作的。(如果忘記了哪些是基本數(shù)據(jù)類型,可以往回看。)
對象數(shù)據(jù)類型通過傳址來操作的。(比如 數(shù)組和函數(shù))
例子:
<script>
//傳值
a=1;
b=a;
b=2;
alert(a); //輸出 1

//傳址
x=[1,2];
y=x;  // 賦給y的只是x的一個引用,而不是x本身。數(shù)組已經(jīng)在語句中被賦值了,執(zhí)行過這段代碼后,仍舊只有一個數(shù)組對象,只不過我們有2個對他的引用了。
y[0]=2;
alert(x[0] +" | " +x[1]);  //輸出 2  |  2
</script>
其中我們必須注意字符串:
js中字符串是通過傳址來復(fù)制和傳遞的,而他們是通過傳值來比較的。
對象和數(shù)組是用傳值來傳遞的,只不過傳遞的這個值實(shí)際是一個引用,而不是對象本身。
總結(jié):
類型    復(fù)制    傳遞    比較
數(shù)字    傳值    傳值    傳值
布爾    傳值    傳值    傳值
字符串    不可變    不可變    傳值
對象    傳址    傳址    傳址
不可變:在JS中,沒有方法去改變字符串值的內(nèi)容。
對字符串來說,傳值還是傳址,意義不大。

相關(guān)文章

最新評論