DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 跟我學習javascript的隱式強制轉換
跟我學習javascript的隱式強制轉換
編輯:關於JavaScript     

JavaScript的數據類型分為六種,分別為null,undefined,boolean,string,number,object。

object是引用類型,其它的五種是基本類型或者是原始類型。我們可以用typeof方法打印來某個是屬於哪個類型的。不同類型的變量比較要先轉類型,叫做類型轉換,類型轉換也叫隱式轉換。隱式轉換通常發生在運算符加減乘除,等於,還有小於,大於等。。

typeof '11' //string 
typeof(11)  //number
'11' < 4 //false

一、基本類型的轉換

下面先講加減乘除:

1. 字符串加數字,數字就會轉成字符串。

2. 數字減字符串,字符串轉成數字。如果字符串不是純數字就會轉成NaN。字符串減數字也一樣。兩個字符串相減也先轉成數字。

3. 乘,除,大於,小於跟減的轉換也是一樣。

//隱式轉換 + - * == / 
// + 
10 + '20' //'2010'
// -
10 - '20' //-10
10 - 'one' //NaN
10 - '100a' //NaN
// *
10*'20' //200
'10'*'20' //200
// /
20/'10' //2
'20'/'10' //2
'20'/'one'  //NaN

4.加法操作順序是敏感的

類似這樣的混合表達式有時令人困惑,因為 JavaScript 對操作順序是敏感的。例如,表達式:1+2+"3";  //"33"

由於加法運算是自左結合的(即左結合律),因此,它等同於下面的表達式:(1+2)+"3";  //"33"

與此相反,表達式:1+"2"+3;  //"123"的計算結果為字符串“123”。左結合律相當於是將表達式左側的加法運算包裹在括號中。

5.再來看看一組 ==

1).undefined等於null

2).字符串和數字比較時,字符串轉數字

3).數字為布爾比較時,布爾轉數字

4).字符串和布爾比較時,兩者轉數字

// ==
undefined == null; //true
'0' == 0;    //true,字符串轉數字
0 == false; //true,布爾轉數字
'0' == false;    //true,兩者轉數字
null == false;   //false
undefined == false;  //false

7個false值:false,0,-0,“”,NaN,null以及undefined,所有其他值都是truth

6、NaN,不是一個數字

NaN 是一個特殊值,說明某些算術運算(如求負數的平方根)的結果不是數字。方法 parseInt() 和 parseFloat() 在不能解析指定的字符串時就返回這個值。對於一些常規情況下返回有效數字的函數,也可以采用這種方法,用 Number.NaN 說明它的錯誤情況。

Math.sqrt(-2)
Math.log(-1)
0/0
parseFloat('foo')

對於很多JavaScript的初學者來說,它的第一個陷阱是調用typeof時返回結果的通常是你想不到的:

console.log(typeof NaN); // 'Number'

這情情況下,NaN並不意味著是一個數字,它的類型是數字。明白嗎?
因為typeof 返回的是字符串,有六種:“number”、”string”、”boolean”、”object”、”function”、”undefined

保持冷靜,因為下面還有很多混亂的地方。讓我們比較兩個NaN:

var x = Math.sqrt(-2);
var y = Math.log(-1);
console.log(x == y); // false

也許這是因為我們沒有使用嚴格等價(===)操作?顯然不是。

var x = Math.sqrt(-2);
var y = Math.log(-1);
console.log(x === y); // false

直接比較兩個NaN呢?

console.log(NaN === NaN); // false

因為有很多方法來表示一個非數字,所以一個非數字不會等於另一個為NaN的非數字,它還是有一定道理的。

但是當然,解決方案現在已經有了。讓我們認識一下全局函數isNaN:

console.log(isNaN(NaN)); // true

唉,不過 isNaN() 也有它自己的很多缺陷呀:

console.log(isNaN('hello')); // true
console.log(isNaN(['x'])); // true
console.log(isNaN({})); // true

這樣又產生了很多不同的解決方案。其中一個是利用 了NaN的非反射性質(例如, 看看 Kit Cambridge 的筆記)

var My = {
 isNaN: function (x) { return x !== x; }
}

不過幸運的是,在即將到來的ECMAScript 6中, 有一個Number.isNaN() 方法提供可靠的NaN值檢測。
換句話說,只有在參數是真正的NaN時,才會返回true

console.log(Number.isNaN(NaN)); // true
console.log(Number.isNaN(Math.sqrt(-2))); // true
console.log(Number.isNaN('hello')); // false
console.log(Number.isNaN(['x'])); // false
console.log(Number.isNaN({})); // false

二、引用類型的轉換

基本類型間的比較相對簡單。引用類型和基本類型的比較就相對復雜一些,先要把引用類型轉成基本類型,再按上述的方法比較。

1.引用類型轉布爾全是true。

比如空數組,只要是對象就是引用類型,所以[]為true。引用類型轉數字或者字符串就要用valueOf()或者toString();對象本身就繼承了valuOf()和toString(),還可以自定義valueOf()和toString()。根據不同的對象用繼承的valueOf()轉成字符串,數字或本身,而對象用toString就一定轉為字符串。一般對象默認調用valueOf()。

1).對象轉數字時,調用valueOf();

2).對象轉字符串時,調用toString();

先看看下面的例子:

0 == []; // true, 0 == [].valueOf(); ---> 0 == 0;
'0' == []; // false, '0' == [].toString(); ---> '0' == '';
2 == ['2']; // true, 2 == ['2'].valueOf(); ---> 2 == '2' ---> 2 == 2;
'2' == [2]; // true, '2' == [2].toString(); ---> '2' =='2';

[] == ![]; //true, [].valueOf() == !Boolean([]) -> 0 == false ---> 0 == 0;

對象轉成數字時,調用valueOf(),在這之前先調用的是toString();所以我猜valueOf方法是這樣的。So上面的例子 0 == []要改成下面更合理。無論如何,[]最後是轉成0的。

var valueOf = function (){
 var str = this.toString(); //先調用toString(),轉成字符串
 //...
}
0 == []; // true, 0 == [].valueOf(); -> 0 == '0' -> 0 == 0;

自定義的valueOf()和toString();

  • 自定義的valueOf()和toString()都存在,會默認調用valueOf();
  • 如果只有toString(),則調用toString();

var a = [1];

a.valueOf = function (){ return 1;}
a.toString = function (){ return '1';}

a + 1; // 2, valueOf()先調用

去掉valueOf()就會調用toString()。

var a = [1];

a.valueOf = function (){ return 1;}
a.toString = function (){ return '1';}

a + 1; // 2, 先調用valueOf()
//去掉valueOf
delete a.valueOf;
a + 1; // '11', 調用toString()

如果返回其它會怎麼樣呢?

var a = [1];

a.valueOf = function (){return ;}
a.toString = function (){return 1 ;};

1 - a; //NaN

其它對象 調用valueOf()轉成不同的類型:

var a = {};
a.valueOf(); //Object {}
var a = [];
a.valueOf(); //[] 自己本身
var a = new Date();
a.valueOf(); //1423812036234 數字
var a = new RegExp();
a.valueOf(); // /(?:)/ 正則對象

引用類型之間的比較是內存地址的比較,不需要進行隱式轉換,這裡不多說。

[] == [] //false 地址不一樣

var a = [];
b = a;
b == a //true

2.顯式轉換

顯式轉換比較簡單,可以直接用類當作方法直接轉換。

Number([]); //0
String([]); //”
Boolean([]); //true

還有更簡單的轉換方法。

3 + ” // 字符串'3'
+'3' // 數字3
!!'3' // true

以上就是本文的全部內容,詳細介紹了javascript的隱式強制轉換,希望對大家的學習有所幫助。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved