js中不同類型的基礎數據之間可以轉換,這種轉換是有規則可尋的,並非隨意的隨機的。在js中有5種基礎類型數據:string、number、boolean、null、undefined,其中,常用於計算或者比較的類型是前面三種。
基礎數據之間的轉換
| 原始數據類型 | 目標類型Number |
| undefined | NaN |
| null | 0 |
| false | 0 |
| true | 1 |
| 數字串 | 相應的數字 |
| 不能轉化的字符串 | NaN |
| 原始數據類型 | 目標類型String |
| undefined | undefined |
| null | null |
| false | false |
| true | true |
| 數字 | 數字字符串 |
不同類型的基礎數據之間的加法,數據先轉換為number,然後轉換為string(如果有string類型數據參與運算)
複製代碼代碼如下:
null + undefined // 0+NaN
null + false // 0+0
1 + true // 1+1
1 + '1' //'11';數字與字符串相加結果是字符串
1 + 2 + '3' //'33';(1+2)的結果然後與'3'相加;這裡要把每一步加法單獨拆開來看,否則變成和下面一樣的結果了.
1 + (2 +'3') //'123';先運算2+'3',然後1+'23'
's' + null //'snull'
's' + undefined // 'sundefined'
's' + true //'strue'
1 + true + undefined + 's' // 1+1+NaN+'s'=2+NaN+'s'=NaN+'s'=NaNs
對象參與加減法運算
對象參與基礎類型數據運算,先轉化為基礎類型。先調用其valueOf方法,如果返回的不是基礎類型,再調用其toString方法,如果返回的還不是基礎類型,則拋出錯誤。但是,Date數據剛好相反
複製代碼代碼如下:
//為了便於觀察重寫Date的toString方法和valueOf方法
Date.prototype.toString = function(){
return 1;
}
Date.prototype.valueOf = function(){
return 2;
}
var a = new Date,
b = new Date;
a + b; // 調用toString,1 + 1,結果是2
// 再重寫toString方法
Date.prototype.toString = function(){
return {};
}
var c = new Date,
d = new Date;
c + d; // 調用toString方法返回的不是基礎類型,再調用valueOf,2 + 2,結果是4
// 再重寫valueOf方法
Date.prototype.valueOf = function(){
return {};
}
var e = new Date,
f = new Date;
e + f; // 報錯
把上面的例子換成Object或者其他類型能得到相應的結果,不過是先調用valueOf,再調用toString。
'+'號的神奇功效
數據前有加號'+',可以讓字符串轉化為數字
複製代碼代碼如下:
+'1'+1 // 2
+'s'+2 // NaN
注:第一次,格式不好,紕漏多,歡迎大家拍磚