亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一篇文章搞定JavaScript類型轉換(面試常見)

 更新時間:2017年01月21日 15:15:24   作者:小不了  
這篇文章主要介紹了一篇文章搞定JavaScript類型轉換(面試常見),非常不錯,具有參考借鑒價值,需要的朋友參考下吧

為啥要說這個東西?一道面試題就給我去說它的動機。

題如下:

var bool = new Boolean(false);
if (bool) {
 alert('true');
} else {
 alert('false');
}

運行結果是true?。?!

其實啥類型轉換啊,操作符優(yōu)先級啊,這些東西都是最最基本的。犀牛書上有詳細的介紹。但我很少去翻犀牛書的前5章。。。

比如說優(yōu)先級那塊兒,很多書都教育我們,“不用去背誦優(yōu)先級順序,不確定的話,加括號就行了?!捌匠N覀儗懘a時也確實這么做的。

但現實是啥呢?面試時會出這種題,讓你來做。。。真不知道這種題的意義是啥。。。

抱怨到此為止,本文嘗試來解決類型轉換問題,爭取把《JS權威指南》49頁那個表背下來。

都有哪些東西是假值?

共6個:

0或+0、-0,NaN
""
false
undefined
null

上面的順序是按照基本類型來排列的。

除此之外的一律不是?。∧呐率侨缦滦问剑?/p>

Infinity
'0'、'false'、" "(空格字符)
任何引用類型:[],{},function(){}

if (a && b)的正確理解方式是:a && b進行表達式求值后,然后再轉換為Boolean類型。

&&是種短路語法,求值后不一定是個Boolean類型,更不是兩邊轉化布爾值再運算。

比如 2&&3 的結果是3,不是true。

所以if(a && b),我們平常理解的那種,"如果a和b同時為真的話",是一種錯誤的描述方式。

其他基本類型轉化為字符串,基本和預期的一樣:

console.log("" + null);   // "null"
console.log("" + undefined); // "undefined"
console.log("" + false);   // "false"
console.log("" + true);   // "true"
console.log("" + 0);     // "0"
console.log("" + NaN);    // "NaN"
console.log("" + Infinity); // "Infinity"

其他基本類型轉化為數字,需要特殊記憶:

console.log(+null);     // 0
console.log(+undefined);   // NaN
console.log(+false);     // 0
console.log(+true);     // 1
console.log(+"");      // 0
console.log(+'1');      // 1
console.log(+'1x');     // NaN 

其中null,空字符是0,undefined是NaN。

以上,基本類型轉換都說明白了。

下面來看看引用類型轉換為基本類型。

引用類型轉換為布爾,始終為true

引用類型轉換為字符串

1.優(yōu)先調用toString方法(如果有),看其返回結果是否是原始類型,如果是,轉化為字符串,返回。

2.否則,調用valueOf方法(如果有),看其返回結果是否是原始類型,如果是,轉化為字符串,返回。

3.其他報錯。

引用類型轉化為數字

1.優(yōu)先調用valueOf方法(如果有),看其返回結果是否是基本類型,如果是,轉化為數字,返回。

2.否則,調用toString方法(如果有),看其返回結果是否是基本類型,如果是,轉化為數字,返回。

3.其他報錯。

首先我們看看常見引用類型toString和valueOf返回什么?

var a = {};
console.dir(a.toString());  // "[object Object]"
console.dir(a.valueOf());  // 對象本身
var b = [1, 2, 3];
console.dir(b.toString());  // "1,2,3"
console.dir(b.valueOf());  // 對象本身
var c = [[1],[2]];
console.dir(c.toString());  // "1,2"
console.dir(c.valueOf());  // 對象本身
var d = function() {return 2};
console.dir(d.toString());  // "function() {return 2}"
console.dir(d.valueOf());  // 對象本身

因此對應的轉換為字符串和數字的情形是:

var a = {};
console.dir(a + "");     // "[object Object]"
console.dir(+a);       // NaN
var b = [1, 2, 3];
console.dir(b + "");     // "1,2,3"
console.dir(+b);       // NaN
var c = [[1],[2]];
console.dir(c + "");     // "1,2"
console.dir(+c);       // NaN
var d = function() {return 2};
console.dir(d + "");     // "function () {return 2}"
console.dir(+d);       // NaN

再來個報錯的情形:

var a = {};
a.toString = function() {return {};}
console.log("" + a);     // 報錯
console.log(+a)       // 報錯

以上類型轉換規(guī)律基本說完。

最后來說一下萬惡的“==”

面試題如下:

var a = false;
var b = undefined;
if (a == b) {
 alert('true');
} else {
 alert('false');
}

本以為會彈出true的。天那!為啥是false?

哈哈。。。

雙等號,如果兩邊類型不同,會有隱式轉換發(fā)生。犀牛書75頁總結如下:

1,null和undefined,相等。

2,數字和字符串,轉化為數字再比較。

3,如果有true或false,轉換為1或0,再比較。

4,如果有引用類型,優(yōu)先調用valueOf。

5,其余都不相等。

因此有:

console.log(undefined == false); // false
console.log(null == false);   // false
console.log(0 == false);     // true
console.log(NaN == false);    // false
console.log("" == false);    // true

0 == false之所以為true根據第3條。

"" == false之所以為true根據第3條,變成了"" == 0,再根據第2條。

第4條再來一個例子:

console.log([[2]] == '2')

其上結果為true,原因如下:

[[2]]的valueOf是對象本身,不是基本類型。

嘗試調用toString的結果是'2'。

因此變成了'2'和數字2的比較。根據第2條,相等。WTF!!

最后說句,使用"==="就沒有這些問題了。

以上所述是小編給大家介紹的一篇文章搞定JavaScript類型轉換(面試常見),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • 小程序如何獲取多個formId實現詳解

    小程序如何獲取多個formId實現詳解

    這篇文章主要介紹了小程序如何獲取多個formId實現詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-09-09
  • JavaScript日期和時間的格式化及其它常用處理方法

    JavaScript日期和時間的格式化及其它常用處理方法

    這篇文章主要給大家介紹了關于JavaScript日期和時間的格式化及其它常用處理方法,JavaScript中可以使用Date對象來表示日期和時間,如果需要格式化日期和時間,可以使用Date對象的幾個方法和一些字符串操作方法來實現,需要的朋友可以參考下
    2023-09-09
  • es6中l(wèi)et和const的使用方法詳解

    es6中l(wèi)et和const的使用方法詳解

    這篇文章主要介紹了es6中l(wèi)et和const的使用方法,結合實例形式詳細分析了es6中l(wèi)et和const的基本功能、原理、使用方法及操作注意事項,需要的朋友可以參考下
    2020-02-02
  • js 表格拖拽效果實例代碼 (IE only)

    js 表格拖拽效果實例代碼 (IE only)

    拖拽交換Table的列(I.E. ONLY)
    2010-02-02
  • UEditor 自定義圖片視頻尺寸校驗功能的實現代碼

    UEditor 自定義圖片視頻尺寸校驗功能的實現代碼

    UEditor支持單圖、多圖以及視頻上傳,編輯器配置項支持文件格式、文件大小校驗,對于文件寬高尺寸校驗暫不支持。本文給大家介紹UEditor 自定義圖片視頻尺寸校驗功能的實現代碼,感興趣的朋友一起看看吧
    2020-10-10
  • Javascript中的方法和匿名方法實例詳解

    Javascript中的方法和匿名方法實例詳解

    這篇文章主要介紹了Javascript中的方法和匿名方法,以實例形式較為詳細的分析了javascript中方法及匿名方法的定義與使用技巧,需要的朋友可以參考下
    2015-06-06
  • opencv 識別微信登錄驗證滑動塊位置

    opencv 識別微信登錄驗證滑動塊位置

    這篇文章主要介紹了opencv 識別微信登錄驗證滑動塊位置及各自的優(yōu)缺點,需要的朋友可以參考下
    2018-08-08
  • gojs實現螞蟻線動畫效果

    gojs實現螞蟻線動畫效果

    這篇文章介紹了gojs實現螞蟻線動畫效果的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • javascript實現在某個元素上阻止鼠標右鍵事件的方法和實例

    javascript實現在某個元素上阻止鼠標右鍵事件的方法和實例

    這篇文章主要介紹了javascript實現在某個元素上阻止鼠標右鍵事件的方法和實例,需要的朋友可以參考下
    2014-08-08
  • JavaScript實現網頁版五子棋游戲

    JavaScript實現網頁版五子棋游戲

    這篇文章主要為大家詳細介紹了JavaScript實現網頁版五子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07

最新評論