javascript不一樣類型數據之間的運算是如何轉換的

      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

 注:第一次,格式很差,紕漏多,歡迎你們拍磚字符串

相關文章
相關標籤/搜索