溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

JS表達(dá)式實例分析

發(fā)布時間:2022-06-28 09:35:11 來源:億速云 閱讀:114 作者:iii 欄目:web開發(fā)

本篇文章和大家了解一下JS表達(dá)式實例分析。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

JS表達(dá)式實例分析

挑戰(zhàn)

在這個挑戰(zhàn)中,你將看到20個古怪表達(dá)式,并要猜出其輸出結(jié)果。

1.

true + false

2.

**1.**

3.

[1, 2, 3] + [4, 5, 6]

4.

0.2 + 0.1 === 0.3

5.

10,2

6.

!!""

7.

+!![]

8.

true == "true"

9.

010 - 03

10.

"" - - ""

11.

null + 0

12.

0/0

13.

1/0 === 10 ** 1000

14.

true++

15.

"" - 1

16.

(null - 1) - "1"

17.

38 * 4343 * 2342+ (“true” — 0)

18.

5 + !5 + !!5

19.

[] + [1] + 2

20.

1 + 2 + "3"

結(jié)果和分析

true + false

試圖在兩個布爾值之間使用加法運算符(+)時,它們會被轉(zhuǎn)換為數(shù)字。

而且我們都知道true應(yīng)該被轉(zhuǎn)換為1,false應(yīng)該被轉(zhuǎn)換為0。所以true+false返回1。

[,,,].length

[,,,] 輸出一個有三個空槽的數(shù)組。最后一個逗號是尾部的逗號。

你可以這么想。

[,]     ==> [empty,]
[,,]    ==> [empty, empty,]
[,,,]   ==> [empty, empty, empty,]

所以 [,,,].length 返回3。

[1, 2, 3] + [4, 5, 6]

當(dāng)你試圖在數(shù)組之間使用加法運算符(+)時,它們會被轉(zhuǎn)換為字符串。

將一個數(shù)組轉(zhuǎn)換為字符串時,數(shù)組的 toString() 方法被調(diào)用。toString()方法是JavaScript 內(nèi)部使用的,當(dāng)一個數(shù)組需要顯示為文本時,它將用逗號連接其元素。

[1, 2, 3].toString() ==> '1, 2, 3'
[4, 5, 6].toString() ==> '4, 5, 6'

所以

[1, 2, 3] + [4, 5, 6] ==> '1, 2, 3' + '4, 5, 6' ==> "1,2,34,5,6"

0.2 + 0.1 === 0.3

由于浮點數(shù)很難在計算機中準(zhǔn)確表示,數(shù)學(xué)上的0.10.2在計算機中只能用近似的數(shù)字表示。

0.1+0.2的結(jié)果不完全是0.3。不僅僅是JavaScript,其他編程語言也有同樣的問題。

10, 2

逗號(,)在JavaScript中也是一個合法的操作符,它評估每個操作數(shù)(從左到右),并返回最后一個操作數(shù)的值。

因此,10,2返回2

!!""

""是一個空字符串,它是一個虛值。

注意:0、空字符串""、null 和undefined都是虛值。

! 是邏輯上的 "非 "運算符,把 true 變成 false,反之亦然。

如果我們使用兩次!,也就是!!,它將把一個正常的值轉(zhuǎn)換成一個布爾值。所以!""返回 false

+!![]

數(shù)組都是真值,甚至是空數(shù)組。所以!![]將返回true

!![]; // -> true

+號會將真值轉(zhuǎn)換為其數(shù)字表示: 1,所以 +!![] 返回 1。

true == "true"

雙等運算符(==)檢查其兩個操作數(shù)是否相等,并返回一個布爾值結(jié)果。

根據(jù)抽象的雙等比較規(guī)則,這兩個值在比較時都被轉(zhuǎn)換為數(shù)字。

true == "true" ==> Number(true) == Number("true") ==> 1 == NaN

所以,ture =="true" 返回false。

010 - 03

這里有一個小小的技巧:如果一個數(shù)字以0開頭,那么在JavaScript中它就被當(dāng)作一個八進制數(shù)字。所以:

010 - 03 ==> 8 - 3 ==> 5

另外:

  • 如果一個數(shù)字以0b開頭,那么它在JavaScript中被視為二進制數(shù)字。

  • 如果一個數(shù)字以0x開頭,它在JavaScript中被當(dāng)作一個十六進制數(shù)字。

JS表達(dá)式實例分析

""--""

這看起來是一個錯誤的語法,但它確實工作正常。

空字符串可以被轉(zhuǎn)換為布爾值false或數(shù)字值0。所以 -""0

JS表達(dá)式實例分析

null + 0

正如我們之前所說,null是一個虛值。它將被轉(zhuǎn)換為布爾值false或數(shù)字值0。所以結(jié)果返回 0。

0/0

這是一個非法的數(shù)學(xué)表達(dá)式。方程0/0沒有任何有意義的數(shù)字答案,輸出的結(jié)果只是NaN。

1/0 === 10 1000**

雖然1/0和之前一樣也是一個非法的數(shù)學(xué)表達(dá)式。但是當(dāng)除數(shù)不是0時,JavaScript認(rèn)為這個表達(dá)式的結(jié)果是Infinity

JS表達(dá)式實例分析

10**1000是一個很大數(shù)字,JS 無法正確表示這個數(shù)字。(JavaScript中最高的整數(shù)值是2^53-1)。所以10 * 1000也被當(dāng)作無限大(Infinity)。

無窮大總是等于另一個無窮大,所以1/0 === 10 ** 1000返回 true。

true++

這沒有什么特別的,這只是一個語法錯誤。

JS表達(dá)式實例分析

""- 1

雖然加法運算符(+)同時用于數(shù)字和字符串,但減法運算符(-)對字符串沒有用處,所以JavaScript將其解釋為數(shù)字之間的操作。一個空的字符串會被類型強制為0。

"" - 1 ==> Number("") - 1 ==> 0 - 1 ==> -1

所以 "" — 1 返回 -1

(null - 1) - "1"

正如上面所說。

null ==>  0
(null - 1) ==> -1
"1" ==> 1

所以 (null — 1) — “1” 返回 -2

38 4343 2342+ ("true" - 0)

你可能會懷疑JS是如此瘋狂,以至于它將字符串 "true" 轉(zhuǎn)換為布爾值 true 的數(shù)字表示。然而,它并沒有那么瘋狂。實際發(fā)生的情況是,它試圖將字符串轉(zhuǎn)換為數(shù)字,但失敗了。

Number("true"); // -> NaN

在JavaScript的數(shù)字運算中,只要有一個值是NaN,運算的最終結(jié)果就一定是NaN。38 * 4343 * 2342只是一個煙霧彈。

5 + !5 + !!5

正如上面所說。

  • 0、空字符串""、null和undefined都是虛值。

  • 非零的數(shù)字是真值。

所以:

!5 ==> 0
!!5 ==> 1

[] + [1] + 2

試圖在數(shù)組之間使用加法運算符(+)時,它們會被轉(zhuǎn)換為字符串。

[] ==> ''
[1] ==> '1'
[] + [1] ==> '1'
'1' + 2 ==> '12'

所以結(jié)果是'12'。

JS表達(dá)式實例分析

1 + 2 + "3"

JavaScript 從左到右執(zhí)行這些操作。當(dāng)數(shù)字3與字符串3相加時,字符串連接將優(yōu)先進行。

1 + 2; // -> 3
3 + "3"; // -> "33"

以上就是JS表達(dá)式實例分析的簡略介紹,當(dāng)然詳細(xì)使用上面的不同還得要大家自己使用過才領(lǐng)會。如果想了解更多,歡迎關(guān)注億速云行業(yè)資訊頻道哦!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI