1,對象跟基本類型之間的轉換:
不管何時,只是對象非空,在布爾環境中都為true.
如;
new Boolean(false);
new Number(0);
new String(“”);
new Array();
上面雖然內部值是false,但對象的值是true;
Object ? valueOf() ? toString()
其中Date類,是先執行toString()轉換。
2,js中操作一個資料值:
任何語言都有自己的操作資料的方法;
Js也不例外,js有3種重要的方式來操作一個資料值。
1) 複製它。例如把它賦給一個新的變數。
2) 把它作為參數傳遞給一個函數或方法。
3) 可以和其他值比較大小。
Js通過傳值和傳址2種方式操作這些資料的值。
從名稱可以看處,傳值 是通過傳遞值來操作資料。在賦值的過程中,對實際的值進行了拷貝,儲存到一個新的變數中。拷貝的值和原來的值是2份完全獨立的值。所以如果你改變了拷貝的值,並不會影響原來的值。當比較大小時候,通常進行琢個位元組比較。
傳址 從名字來看,就是通過傳遞地址來操作資料。在賦值的過程中,對實際的值的地址(可以說是引用)進行了拷貝,他們不是完全的獨立,所以如果你通過引用改變了值,那麼原始的值也會改變。當比較大小的時候,通常是看他們是否引用同一個地址來比較。
簡單的傳址例子:
var a = new Date();
alert(a.getDate());
var b = a ;
b.setDate(21);
alert(a.getDate()) // 輸出21
3,一般來說:
基礎資料型別 (Elementary Data Type)通過傳值來操作的。(如果忘記了哪些是基礎資料型別 (Elementary Data Type),可以往回看。)
對象資料類型通過傳址來操作的。(比如 數組和函數)
例子:
<script>
//傳值
a=1;
b=a;
b=2;
alert(a); //輸出 1
//傳址
x=[1,2];
y=x; // 賦給y的只是x的一個引用,而不是x本身。數組已經在語句中被賦值了,執行過這段代碼後,仍舊只有一個數組對象,只不過我們有2個對他的引用了。
y[0]=2;
alert(x[0] +" | " +x[1]); //輸出 2 | 2
</script>
其中我們必須注意字串:
js中字串是通過傳址來複製和傳遞的,而他們是通過傳值來比較的。
對象和數組是用傳值來傳遞的,只不過傳遞的這個值實際是一個引用,而不是對象本身。
總結:
類型 複製 傳遞 比較
數字 傳值 傳值 傳值
布爾 傳值 傳值 傳值
字串 不可變 不可變 傳值
對象 傳址 傳址 傳址
不可變:在JS中,沒有方法去改變字串值的內容。
對字串來說,傳值還是傳址,意義不大。