资讯专栏INFORMATION COLUMN

JS 中有趣的事实

godruoyi / 541人阅读

摘要:在这种情况下,表示没有值。因此,不应该是的实例。事实是,将浮点数存储为二进制。比小返回的事实看起来是错误的,但实际上它是正确的。没有整数数据类型在中,没有整数数据类型。函数自动类型转换函数自动将值转换为字符串,这就会导致奇怪的事情发生。

为了保证的可读性,本文采用意译而非直译。

想阅读更多优质文章请猛戳GitHub博客,一年百来篇优质文章等着你!

使用 JS 有很多有趣的地方。尽管工程师们每天都在与之打交道,但仍有一些语言没有被开发出来。本广将介绍一些你可能想不到的JS特性。

NaN 是一个 number 类型

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

> typeof(NaN)
"number"

> NaN === NaN
false
null 是一个对象

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

> typeof(null)
"object"

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

> null instanceof Object
false    
    
undefined 可以被定义

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

> var some_var;
undefined
> some_var == undefined
true
> undefined = "i am undefined"   
0.1 + 0.2 不等于 to 0.3

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

> 0.1 + 0.2
0.30000000000000004
> 0.1 + 0.2 == 0.3
false    
Math.max() 比 Math.min() 小

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

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

    
> Math.max()
-Infinity
> Math.min()
Infinity    
018 - 045 = -19

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

> 018 - 045
-19    

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

函数可以自执行

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

> (function()  { console.log("I am self executing");  })();
I am self executing    

括号的位置问题
`return` 语句后面没有东西的时候它什么都不返回。 实际上,JS 后面 `return` 添加一个 `;`。

> function foo() {
   return
   {
      foo: "bar"
   }
}
> foo(); 
undefined

> function foo() {
   return {
      foo: "bar"
   }
}
> foo(); 
{foo: "bar"}


没有整数数据类型

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

sort() 函数自动类型转换

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

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

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

> [1,5,20,10].sort(function(a, b){return a - b});
(4) [1, 10, 20, 5]
数组和对象的和
> !+[]+!![]+!![]+!![]+!![]+!![]+!![]+!![]+!![]
9
> {} + []
0
> [] + {}
"[object Object]"
> [] + []
""
> {} + {}
"[object Object][object Object]"
> {} + [] == [] + {}
true
交流

干货系列文章汇总如下,觉得不错点个Star,欢迎 加群 互相学习。

https://github.com/qq44924588...

我是小智,公众号「大迁世界」作者,对前端技术保持学习爱好者。我会经常分享自己所学所看的干货,在进阶的路上,共勉!

关注公众号,后台回复福利,即可看到福利,你懂的。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/105926.html

相关文章

  • 一步步搭建物联网系统——无处不在CSS

    摘要:与类选择器最常一起出现的是选择器,不过这个适用于比较高级的场合,诸如用控制的时候就需要用到选择器。在线查看一步步搭建物联网系统图灵电子书版一步步搭建物联网系统 无处不在的CSS 或许你觉得CSS一点儿也不重要,而事实上,如果说HTML是建筑的框架,CSS就是房子的装修。那么Javascript呢,我听到的最有趣的说法是小三——还是先让我们回到代码上来吧。 CSS 下面就是我们之前...

    andot 评论0 收藏0
  • 一步步搭建物联网系统——无处不在CSS

    摘要:与类选择器最常一起出现的是选择器,不过这个适用于比较高级的场合,诸如用控制的时候就需要用到选择器。在线查看一步步搭建物联网系统图灵电子书版一步步搭建物联网系统 无处不在的CSS 或许你觉得CSS一点儿也不重要,而事实上,如果说HTML是建筑的框架,CSS就是房子的装修。那么Javascript呢,我听到的最有趣的说法是小三——还是先让我们回到代码上来吧。 CSS 下面就是我们之前...

    dreambei 评论0 收藏0
  • 【译】统一样式语言

    摘要:原文地址原文作者译文出自掘金翻译计划译者校对者统一样式语言在过去几年中,我们见证了的兴起,尤其是在社区。根本上来说,纯粹用于只是一个命名规范,它要求样式的类名要遵守的模式。 原文地址:A Unified Styling Language 原文作者:Mark Dalgleish 译文出自:掘金翻译计划 译者:ZhangFe 校对者:JackGit,yifili09 统一样式语言 在过...

    fjcgreat 评论0 收藏0
  • 从谷歌JavaScript编写风格,13 点值得我们注意

    摘要:谷歌和有两个最受欢迎的编写风格指南。有趣的是,谷歌和不同意这个规则这是的规范。谷歌只是众多科技巨头之一,这些只是推荐。也就是说,看看谷歌这样的公司提出的风格建议是很有趣的,这家公司雇佣了很多才华横溢的人,他们花了很多时间编写优秀的代码。 showImg(https://segmentfault.com/img/bV7pRb?w=2000&h=800); 文中的我指原文的作者 想阅读更多...

    zhonghanwen 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<