js中不一樣類型的基礎數據之間能夠轉換,這種轉換是有規則可尋的,並不是隨意的隨機的。在js中有5種基礎類型數據:string、number、boolean、null、undefined,其中,經常使用於計算或者比較的類型是前面三種。javascript
基礎數據之間的轉換java
原始數據類型 | 目標類型Number |
undefined | NaN |
null | 0 |
false | 0 |
true | 1 |
數字串 | 相應的數字 |
不能轉化的字符串 | NaN |
原始數據類型 | 目標類型String |
undefined | undefined |
null | null |
false | false |
true | true |
數字 | 數字字符串 |
不一樣類型的基礎數據之間的加法,數據先轉換爲number,而後轉換爲string(若是有string類型數據參與運算)spa
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數據恰好相反prototype
//爲了便於觀察重寫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。對象
'+'號的神奇功效blog
數據前有加號‘+’,能夠讓字符串轉化爲數字ip
+'1'+1 // 2 +'s'+2 // NaN
注:第一次,格式很差,紕漏多,歡迎你們拍磚字符串