使用 JS 有很多有趣的地方。尽管工程师们每天都在与之打交道,但仍有一些语言没有被开发出来。本广将介绍一些你可能想不到的JS特性。
[h1]NaN 是一个 number 类型[/h1]是一个类型。而且,不等于它自己。实际上不等于任何东西,验证一个变量是否是可以使用方法来判断。- > typeof(NaN)"number"> NaN === NaNfalse
复制代码 [h1]null 是一个对象[/h1]是一个对象。听起来奇怪!对?但这是事实。在这种情况下,表示没有值。因此,不应该是的实例。- > null instanceof Objectfalse
复制代码 [h1]undefined 可以被定义[/h1]不是 JS 中的保留关键字, 你可以为其指定值也不会报错,如果声明一个变量没有赋值,默认为- > var some_var;undefined> some_var == undefinedtrue> undefined = 'i am undefined'
复制代码 [h1]0.1 + 0.2 不等于 to 0.3[/h1]在JavaScript中,返回。事实是,javascript 将浮点数存储为二进制。- > 0.1 + 0.20.30000000000000004> 0.1 + 0.2 == 0.3false
复制代码 [h1]Math.max() 比 Math.min() 小[/h1]返回的事实看起来是错误的,但实际上它是正确的。
如果没有参数传给或,那么它将返回以下值。- > Math.max()-Infinity> Math.min()Infinity
复制代码 [h1]018 - 045 = -19[/h1]在JavaScript中,前缀会把任何数字转换成八进制。但是,八进制中不使用,任何包含的数字都将被无声地转换为常规的十进制数字。因此,实际上等于十进制表达式,因为是八进制,但是十进制。
[h1]函数可以自执行[/h1]只需创建一个函数,并在调用其他函数时立即调用它,并使用语法- > (function() { console.log('I am self executing'); })();I am self executing
复制代码 [h1]括号的位置问题[/h1]- `return` 语句后面没有东西的时候它什么都不返回。实际上,JS 后面 `return` 添加一个 `;`。> function foo() { return { foo: 'bar' }}> foo();undefined> function foo() { return { foo: 'bar' }}> foo();{foo: "bar"}
复制代码 [h1]没有整数数据类型[/h1]在 JS 中,没有(整数)数据类型。所有数字均为类型。实际上它将数的浮点值存储在内存上。
[h1]sort() 函数自动类型转换[/h1]函数自动将值转换为字符串,这就会导致奇怪的事情发生。- > [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]
复制代码 [h1]数组和对象的和[/h1]- > !+[]+!![]+!![]+!![]+!![]+!![]+!![]+!![]+!![]9> {} + []0> [] + {}"[object Object]"> [] + []""> {} + {}"[object Object][object Object]"> {} + [] == [] + {}true
复制代码
|
|