「知识点」JavaScript 中11个有趣的事实


「知识点」JavaScript 中11个有趣的事实


1 NaN 是一个 number 类型

NaN是一个number类型。 而且,NaN不等于它自己。 实际上NaN不等于任何东西,验证一个变量是否是NaN可以使用isNaN()方法来判断。

<code>> typeof(NaN)"number"> NaN === NaNfalse/<code>


2 null 是一个对象

null是一个对象。 听起来奇怪! 对? 但这是事实。

<code>> typeof(null)"object"/<code>

在这种情况下,null表示没有值。因此,null不应该是Object的实例。

<code>> null instanceof Objectfalse    /<code>

我自己是一名从事了多年开发的web前端老程序员,目前辞职在做自己的web前端私人定制课程,去年我花了一个月整理了一份最适合2019年学习的web前端学习干货,各种框架都有整理,送给每一位前端小伙伴,想要获取的可以关注我的头条号并在后台私信我:前端,即可免费获取。

3 undefined 可以被定义

undefined不是 JS 中的保留关键字, 你可以为其指定值也不会报错,如果声明一个变量没有赋值,默认为undefined

<code>> var some_var;undefined> some_var == undefinedtrue> undefined = 'i am undefined'   /<code>


4 0.1 + 0.2 不等于 to 0.3

在JavaScript中,0.1 +0.2 == 0.3返回false。 事实是,javascript 将浮点数存储为二进制。

<code>> 0.1 + 0.20.30000000000000004> 0.1 + 0.2 == 0.3false /<code>


「知识点」JavaScript 中11个有趣的事实


5 Math.max() 比 Math.min() 小

Math.max() > Math.min()返回false的事实看起来是错误的,但实际上它是正确的。

如果没有参数传给min()或max(),那么它将返回以下值。

<code>> Math.max()-Infinity> Math.min()Infinity    /<code>


6 018 - 045 = -19

在JavaScript中,前缀0会把任何数字转换成八进制。但是,八进制中不使用8,任何包含8的数字都将被无声地转换为常规的十进制数字。

<code>> 018 - 045-19   /<code>

因此,018-019实际上等于十进制表达式18-37,因为045是八进制,但018是十进制。


7 函数可以自执行

只需创建一个函数,并在调用其他函数时立即调用它,并使用()语法

<code>> (function()  { console.log('I am self executing');  })();I am self executing    /<code>


8 括号的位置问题

<code>`return` 语句后面没有东西的时候它什么都不返回。 实际上,JS 后面 `return` 添加一个 `;`。> function foo() {   return   {      foo: 'bar'   }}> foo(); undefined> function foo() {   return {      foo: 'bar'   }}> foo(); {foo: "bar"}/<code>


9 没有整数数据类型

在 JS 中,没有int(整数)数据类型。 所有数字均为Number类型。 实际上它将int数的浮点值存储在内存上。


10 sort() 函数自动类型转换

sort()函数自动将值转换为字符串,这就会导致奇怪的事情发生。

<code>> [1,5,20,10].sort()(4) [1, 10, 20, 5]/<code>

但是,它可以通过比较来解决:

<code>> [1,5,20,10].sort(function(a, b){return a - b});(4) [1, 5, 10, 20]/<code>


11 数组和对象的和

<code>> !+[]+!![]+!![]+!![]+!![]+!![]+!![]+!![]+!![]9> {} + []0> [] + {}"[object Object]"> [] + []""> {} + {}"[object Object][object Object]"> {} + [] == [] + {}true/<code>
<code>> !+[]+!![]+!![]+!![]+!![]+!![]+!![]+!![]+!![]9> {} + []0> [] + {}"[object Object]"> [] + []""> {} + {}"[object Object][object Object]"> {} + [] == [] + {}true/<code>
「知识点」JavaScript 中11个有趣的事实

原文链接:https://zhuanlan.zhihu.com/p/75428509


分享到:


相關文章: