JS表达式实例分析(JS,web开发)

时间:2024-05-03 08:01:39 作者 : 石家庄SEO 分类 : web开发
  • TAG :

JS表达式实例分析

挑战

在这个挑战中,你将看到20个古怪表达式,并要猜出其输出结果。

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"

结果和分析

true + false

试图在两个布尔值之间使用加法运算符(+)时,它们会被转换为数字。

而且我们都知道true应该被转换为1false应该被转换为0。所以true+false返回1

[,,,].length

[,,,] 输出一个有三个空槽的数组。最后一个逗号是尾部的逗号。

你可以这么想。

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

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

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

当你试图在数组之间使用加法运算符(+)时,它们会被转换为字符串。

将一个数组转换为字符串时,数组的 toString() 方法被调用。toString()方法是JavaScript 内部使用的,当一个数组需要显示为文本时,它将用逗号连接其元素。

[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

由于浮点数很难在计算机中准确表示,数学上的0.10.2在计算机中只能用近似的数字表示。

0.1+0.2的结果不完全是0.3。不仅仅是JavaScript,其他编程语言也有同样的问题。

10, 2

逗号(,)在JavaScript中也是一个合法的操作符,它评估每个操作数(从左到右),并返回最后一个操作数的值。

因此,10,2返回2

!!""

""是一个空字符串,它是一个虚值。

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

! 是逻辑上的 "非 "运算符,把 true 变成 false,反之亦然。

如果我们使用两次!,也就是!!,它将把一个正常的值转换成一个布尔值。所以!""返回 false

+!![]

数组都是真值,甚至是空数组。所以!![]将返回true

!![];//->true

+号会将真值转换为其数字表示: 1,所以 +!![] 返回 1

true == "true"

双等运算符(==)检查其两个操作数是否相等,并返回一个布尔值结果。

根据抽象的双等比较规则,这两个值在比较时都被转换为数字。

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

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

010 - 03

这里有一个小小的技巧:如果一个数字以0开头,那么在JavaScript中它就被当作一个八进制数字。所以:

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

另外:

  • 如果一个数字以0b开头,那么它在JavaScript中被视为二进制数字。

  • 如果一个数字以0x开头,它在JavaScript中被当作一个十六进制数字。

JS表达式实例分析

""--""

这看起来是一个错误的语法,但它确实工作正常。

空字符串可以被转换为布尔值false或数字值0。所以 -""0

JS表达式实例分析

null + 0

正如我们之前所说,null是一个虚值。它将被转换为布尔值false或数字值0。所以结果返回 0

0/0

这是一个非法的数学表达式。方程0/0没有任何有意义的数字答案,输出的结果只是NaN

1/0 === 10 1000**

虽然1/0和之前一样也是一个非法的数学表达式。但是当除数不是0时,JavaScript认为这个表达式的结果是Infinity

JS表达式实例分析

10**1000是一个很大数字,JS 无法正确表示这个数字。(JavaScript中最高的整数值是2^53-1)。所以10 * 1000也被当作无限大(Infinity)。

无穷大总是等于另一个无穷大,所以1/0 === 10 ** 1000返回 true。

true++

这没有什么特别的,这只是一个语法错误。

JS表达式实例分析

""- 1

虽然加法运算符(+)同时用于数字和字符串,但减法运算符(-)对字符串没有用处,所以JavaScript将其解释为数字之间的操作。一个空的字符串会被类型强制为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" 转换为布尔值 true 的数字表示。然而,它并没有那么疯狂。实际发生的情况是,它试图将字符串转换为数字,但失败了。

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

在JavaScript的数字运算中,只要有一个值是NaN,运算的最终结果就一定是NaN。38 * 4343 * 2342只是一个烟雾弹。

5 + !5 + !!5

正如上面所说。

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

  • 非零的数字是真值。

所以:

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

[] + [1] + 2

试图在数组之间使用加法运算符(+)时,它们会被转换为字符串。

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

所以结果是'12'。

JS表达式实例分析

1 + 2 + "3"

JavaScript 从左到右执行这些操作。当数字3与字符串3相加时,字符串连接将优先进行。

1+2;//->33+"3";//->"33"
 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:JS表达式实例分析的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:python程序设计的方法下一篇:

15 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18