20个稀奇古怪的 JavaScript 表达式,你能答对几道

20个稀奇古怪的 JavaScript 表达式,你能答对几道

JavaScript是一种非常容错的编程语言,许多在其他编程语言中不合法的表达式在JavaScript中都能正常工作。

这导致了很多奇怪的代码。你想挑战它吗?

挑战

在这个挑战中,你将看到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应该被转换为1,false应该被转换为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.1和0.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中被当作一个十六进制数字。

** “”–“” **

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

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

null + 0

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

0/0

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

1/0 === 10 ** 1000

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

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

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

true++

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

“”- 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’。

1 + 2 + “3”

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

1 + 2; // -> 33 + “3”; // -> “33”

总结

坦率地说,这些挑战并没有为我胶们编码技能提供任何价值,所以不应该在实际项目中写这种代码

但是,把这些技巧作为朋友和同事之间的一些装13,不是一件非常有趣的事情吗?

作者:Marina Mosti 译者:前端小智 来源:medium 原文:https://medium.com/frontend-canteen/20-useless-but-funny-challange-for-javascript-develor-9eea39bb8efb

郑重声明:本文内容及图片均整理自互联网,不代表本站立场,版权归原作者所有,如有侵权请联系管理员(admin#wlmqw.com)删除。
(0)
用户投稿
上一篇 2022年6月27日
下一篇 2022年6月27日

相关推荐

  • 长期看好数字货币,数据中心新基础设施板块

    前期炒作过一波以后,整个板块调整比较充分,很多强势个股都已跌到上一波的起涨点附近,最近国家密集出台经济刺激措施,主要还在老的基础设施板块,但是新基础设施建设才是中国的未来。因此新时…

    2022年6月16日
  • 航天数字藏品,百度又搞了个大动作

    作者 丨苏樵 媒体丨NFT营销工场 神舟十四号飞船即将发射,为了让更多普通人体验航天热情和科技自豪,NFT营销工场独家获悉,中国探月航天将公开招募首批太空数字乘客,以在百度超级链上…

    2022年8月16日
  • 密码箱忘记密码怎么开锁简单(密码箱被锁打开小窍门)

    拿出密码箱找一个光线好的地方,从密码转轮的缝隙看去,拨动密码转轮,你会发现有一个缺口(凹进去的)。 如图:数字7和4缝隙都是正常的,数字0缝隙那个是缺口(凹进去的)。(找光线好的地…

    2022年5月6日
  • 探索式软件测试

    目录 1、概念 2、手工测试 3、探索式测试 4、局部探索式测试法 5、全局探索式测试法 6、混合探索式测试技术 7、实践中的探索式测试 8、测试需要培养的方向 1、概念 1、软件…

    2022年7月13日
  • Python入门系列(六)一篇学会python函数

    函数 函数是只在调用时运行的代码块。 def my_function(): print(“Hello from a function”)my_functio…

    2022年8月22日
  • 数字人民币什么时候全国使用 试点城市有哪些?

    最近几年,数字人民币是一个很热门的话题,这是是由中国人民银行发行的数字形式的法定货币,那么数字人民币什么时候全国使用?数字人民币试点城市有哪些?下文就来带大家了解一下。 数字人民币…

    2022年8月27日
  • 世界青年发展论坛关注数字经济

    记者24日从共青团中央获悉,世界青年发展论坛数字经济主题论坛23日在京举行。论坛设有开幕致辞、主旨演讲、青年行动案例分享、嘉宾对话等环节,20余名来自世界各地的专家学者、青年代表等…

    2022年8月3日
  • 多元探索纾解门票依赖

    近年来,各地的主题乐园纷纷努力转型升级,摆脱传统的“门票经济”,与大IP结合成为行业探索的新赛道。7月30日,上海海昌海洋公园内的全球首个奥特曼主题馆开业,被业界视为本土主题公园走…

    2022年8月13日
  • 操作怪兽打败超级英雄!《巨击大乱斗》新预告公开-

    特摄风格对战游戏《巨击大乱斗》官方今天(3月22日)公开了新的预告,该做是一款四人擂台对战游戏,玩家能够感受到那种浓浓的日本特摄剧的风格。玩家能操作的角色不只有超级英雄,还有巨型怪…

    2022年6月30日
  • 华为常成:产学研政用携手建设算力网络 助力数字经济高质量发展

    6月23日,新华网客户端与至顶网联合举办的《对话数字中国》特别节目——“东数西算”发展研讨会暨《人类计算简史》新书发布会成功举办。华为中国政企数据中心解决方案总裁常成出席研讨会,分…

    2022年6月25日

联系我们

联系邮箱:admin#wlmqw.com
工作时间:周一至周五,10:30-18:30,节假日休息