>웹 프론트엔드 >JS 튜토리얼 >20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!

20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!

青灯夜游
青灯夜游앞으로
2022-06-27 13:41:282165검색

이 기사에서는 20가지 이상한 JavaScript 표현을 공유하겠습니다. 출력 결과에 답해 주실 수 있나요? 와서 도전에 답하세요!

20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!

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"

14.

010 - 03

15.

"" - - ""

16.

null + 0

17.

0/0

18.

1/0 === 10 ** 1000

19.

true++

20 .

"" - 1

Results and Analysis

true + false

두 부울 값 사이에 더하기 연산자(+)를 사용하려고 하면 숫자로 변환됩니다.

그리고 우리 모두는 true1로 변환되어야 하고, false0으로 변환되어야 한다는 것을 알고 있습니다. 따라서 true+false1을 반환합니다.

[,,,].length

[,,,] 3개의 빈 슬롯이 있는 배열을 출력합니다. 마지막 쉼표는 후행 쉼표입니다.

이렇게 생각하시면 됩니다.

(null - 1) - "1"
그래서 [,,,].length는 3을 반환합니다.

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

배열 사이에 더하기 연산자(+)를 사용하려고 하면 문자열로 변환됩니다.

배열을 문자열로 변환할 때 배열의 toString() 메서드가 호출됩니다. toString() 메서드는 배열을 텍스트로 표시해야 할 때 JavaScript에서 내부적으로 요소를 쉼표로 연결하는 데 사용됩니다.

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

5 + !5 + !!5
true应该被转换为1false应该被转换为0。所以true+false返回1

[,,,].length

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

你可以这么想。

[] + [1] + 2

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

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

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

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

1 + 2 + "3"

所以

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

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

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

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

true == "true"

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

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

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

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

010 - 03

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

!![]; // -> true

另外:

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

20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!

""--""

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

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

0.2 + 0.1 === 0.3

20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!부동소수점수는 컴퓨터에서 정확하게 표현하기 어렵기 때문에 수학적인 0.10.2는 컴퓨터에서는 대략적인 수치 표현만 사용할 수 있습니다.

0.1+0.2의 결과는 정확히 0.3이 아닙니다. JavaScript뿐만 아니라 다른 프로그래밍 언어에도 동일한 문제가 있습니다.

10, 2

🎜🎜쉼표(,)도 JavaScript의 유효한 연산자이며 각 피연산자(왼쪽에서 오른쪽으로)를 평가하고 마지막 피연산자 값을 반환합니다. 🎜🎜그래서 10,2는 2🎜🎜🎜를 반환합니다!!""🎜🎜🎜""는 빈 문자열이며 가상 값입니다. 🎜
참고: 0, 빈 문자열 "", null 및 정의되지 않음은 모두 가상 값입니다.
🎜!는 논리적 "not" 연산자로, true를 false로 또는 그 반대로 바꿉니다. 🎜🎜!를 두 번 사용하면, 즉 !!는 일반 값을 부울 값으로 변환합니다. 따라서 !""false를 반환합니다. 🎜🎜🎜+!![]🎜🎜🎜배열은 모두 참 값이며, 심지어 빈 배열도 마찬가지입니다. 따라서 !![]true를 반환합니다. 🎜
true == "true" ==> Number(true) == Number("true") ==> 1 == NaN
🎜그리고 + 기호는 실제 값을 숫자 표현인 1로 변환하므로 +!![]를 반환합니다. 1 . 🎜🎜🎜true == "true" 🎜🎜🎜항등 연산자(==)는 두 피연산자가 동일한지 확인하고 부울 결과를 반환합니다. 🎜🎜추상 동등 비교 규칙에 따라 비교 시 두 값 모두 숫자로 변환됩니다. 🎜
010 - 03 ==> 8 - 3 ==> 5
🎜그래서 ture == "true" 는 false를 반환합니다. 🎜🎜🎜010 - 03🎜🎜🎜여기에 약간의 트릭이 있습니다. 숫자가 0으로 시작하면 JavaScript에서 8진수로 처리됩니다. 따라서: 🎜
"" - 1 ==> Number("") - 1 ==> 0 - 1 ==> -1
🎜 또한: 🎜
  • 숫자가 0b로 시작하면 JavaScript에서는 이진수로 처리됩니다.
  • 숫자가 0x로 시작하면 JavaScript에서는 16진수로 처리됩니다.
🎜🎜20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!🎜🎜🎜🎜 ""--"" 🎜🎜🎜이 구문은 잘못된 구문처럼 보일 수 있지만 제대로 작동합니다. 🎜🎜빈 문자열은 부울 값 false 또는 숫자 값 0으로 변환될 수 있습니다. 따라서 -""0🎜🎜🎜🎜🎜🎜🎜🎜null + 0🎜🎜입니다.

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

0/0

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

1/0 === 10 1000**

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

20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!

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

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

true++

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

20가지 이상한 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'。

20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!

1 + 2 + "3"

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

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

总结

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

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

作者:Marina Mosti

来源:medium

原文:https://medium.com/frontend-canteen/20-useless-but-funny-challange-for-javascript-develor-9eea39bb8efb

【相关视频教程推荐:web前端

위 내용은 20가지 이상한 JS 표현식, 출력 결과를 맞춰보세요!의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 segmentfault.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제