时间:2021-05-25
重要
这篇文章中描述的大多数功能已被暂停使用(甚至不推荐使用)。 它们仍然在许多图书中很常见,因此值得学习。
一、逗号运算符
, 是用于分隔表达式并返回链中最后一个表达式的运算符。
这里有三个主要表达式 1 、 2 和 3。所有这些表达式均被求值,最后一个赋给 oo。
我们在 for 循环中看到这个:
当我们要编写短的 lambda 函数时,这会派上用场:
这里有两个语句,第一个将乘法结果推入数组arr,第二个将乘数a和b推入数组。 第二个结果就是返回给调用者的内容。
对于三元运算符,它也很有用,因为与短lambda语法相同,它仅接受表达式而不是语句。
二、in
in 是用于检查对象中属性是否存在的关键字。 我们在 for..in 循环中使用了它,但没有意识到,其实 in 也是一个关键字:)
如果对象上存在属性,则 in 将返回 true ,否则将返回 false。
看,in 可以独立使用,而不是在 for..in 中。
它将检查 "prop" 是否可作为 o 对象中的属性使用。 它返回 true ,因为我们在 o 中定义了 "prop" 属性。
如果我们检查未定义的属性:
它返回 false ,因为 "prop1" 在 o 中未定义。
三、Array 构造函数
你知道我们可以不使用传统方法定义数组吗?
怎么样?
我们也可以使用 Array :
传递给 Array 构造函数的参数的排列将构成其索引的基础。
1 是第一个参数,其索引为 0; 2 是第二个参数,其索引为 1; 3 是第三个参数,其索引为 2。
所以,
和
表达的是一个意思。
但使用 new Array() 有一个问题,例如:
但:
当你仅给 Array 构造函数一个整数(大于等于 0 的整数,否则将会报错)时,才会发生这种情况。 这是为什么喃?
其实,新的 Array 构造函数正在从某些编程语言中提取思想,在这些语言中,你需要为数组指定内存,这样就不会出现 ArrayIndexOutOfBounds 异常。
是的,它实际上是在创建一个长度为 10 的数组。我们在 Javascript 中没有 sizeof 函数,但是 toString 足以证明这一点。
所以,当将一个参数传递给的 new Array,将导致 JS 引擎为传递的参数大小的数组分配空间。
并且这也在 EcmaScript 规范中:
看,这不是矛盾的。 规格中都有所有描述。 在得出任何结论之前,我们应该始终先阅读任何语言的规范。
四、Function 构造函数
你是否知道我们可以使用 Function 构造函数定义 Function 。
你不明白吧? 让我更清楚。 在 JavaScript 中,我们定义如下函数:
我们也可以这样做,来实现相同的功能:
传递给 Function 的参数形成函数的参数和主体。 变量 mul 成为函数名称。
并且,最后一个参数将是函数的主体,而最后一个参数之前的参数将成为函数的参数。
在在 mul 中。 "a" 和 "b" 是函数将接收的参数,"return a * b" 是函数的主体。 它实现将 "a" 和 "b" 相乘并返回结果。
我们使用 mul(…) 调用该函数,并传入参数:
根据 MDN:
Function构造函数创建一个新的Function对象。直接调用此构造函数可用动态创建函数,但会遭遇来自eval的安全问题和相对较小的性能问题。然而,与 eval 不同的是,Function 构造函数只在全局作用域中运行。
五、数组解构
我们可以通过使用元素的索引号来分解数组中的元素。
元素 1 、2 、3 的索引分别为 0、1、2,即:
在日常开发中,我们最常使用的是对象解构:
所以,我们将解构用于数组上:
所以我们可以使用索引号来提取元素。索引是定义数组中元素位置的属性。
相当于:
数组也是对象,这就是为什么要对其进行对象分解的原因,但是还有一种特殊的数组分解语法:
注意:应尽可能避免知道数组中的特定位置信息(开始、结束索引是什么)。
六、使用 length 属性减少数组内容
数组中的 length 属性表示数组中元素的数目。
减小 length 属性值,会使 JS 引擎将数组元素个数减少到与 length 属性的值相等。
arr 的 length 属性值更改为 1,因此 arr 减少了元素个数,使其等于 length 属性值。
如果增加 length 属性,则 JS 引擎将添加元素(未定义的元素)以使数组中的元素数量达到 length 属性的值。
arr 中的元素只有一个,然后我们将长度增加到 5 ,因此又增加了 4 个元素长度,使元素数达到 5。
七、Arguments
我们可以使用 arguments 对象获取传递给函数的参数,而无需在函数中明确定义 arguments 变量:
arguments 对象是数组索引的。 也就是说,属性是数字,因此可以通过键引用进行访问。
arguments 对象是从 Arguments 类实例化的,该类具有一些很酷的属性。
arguments.callee.name 指当前正在调用的函数的名称。
arguments.callee.caller.name 是指调用当前执行函数的函数的名称。
这在可变参数功能中特别有用。
八、跳过 ()
你是否知道实例化对象时可以跳过方括号 () ?
例如:
即使在内置类中,括号也是可选的:
九、void
void 是 JS 中的关键字,用于评估语句并返回未定义。
例如:
logger 方法应该返回 89 ,但是 void 关键字将使其无效并返回 undefined 。
我曾经读到过 undefined 之前可能会被赋予另一个值,而这会伪造其语义。 因此,使用 void 运算符可确保你得到一个真正的 undefined 。 也用于最小化目的。
十、通过 __proto__ 继承
_proto_ 是从 JavaScript 中的对象继承属性的方法。 __proto__ 是 Object.prototype 的访问器属性,它公开访问对象的 [[Prototype]] 。
此 __proto__ 将其 [[Prototype]] 中设置的对象的所有属性设置为目标对象。
让我们看一个例子:
我们有两个对象常量: obj 和 obj2 。 obj 具有 method 属性。 obj2 是一个空的对象常量,即它没有属性。
我们访问 obj2 的 __proto__ 并将其设置为 obj 。 这会将通过 Object.prototype 可访问的 obj 的所有属性复制到 obj2 。 这就是为什么我们可以在 obj2 上调用方法而不会在没有定义的情况下得到错误的原因。
obj2 继承了 obj 的属性,因此 method 方法属性将在其属性中可用。
原型可用于对象,例如对象常量、对象、数组、函数、日期、RegEx、数字、布尔值、字符串。
十一、一元运算符 +
一元 + 运算符将其操作数转换为数字类型。
当我们希望将变量快速转换为 Number 时,这非常方便。
十二、一元运算符 -
一元运算符 - 将其操作数转换为 Number 类型,然后取反。
该运算符将一元 + 运算符的结果取反。 首先,它将操作数转换为其 Number 值,然后取反该值。
此处发生的是,字符串 "23" 将转换为其数字类型,从而得到 23 。然后,此正数将转换为其负数形式 -23 。
如果转换为数值的结果为 NaN ,则不会应用取反。
取负 +0 产生 -0 ,取负 -0 产生 +0 。
十三、指数运算符 **
该运算符用于指定数字的指数。
在数学中, 2^3^ 意味着将 2 乘以三次:
我们可以使用 ** 运算符在 JS 中进行相同的操作:
总结
本文翻译自 11+ JavaScript Features You've Probably Never Used
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
有一个你们可能从未听说的有趣的CSS功能是火狐浏览器独创的-moz-element属性,使用它,你可以用网页上任意的内容作为背景,跟背景图的效果相似。HTML和
如果你熟悉客户端JavaScript编程,你可能使用过setTimeout和setInterval函数,这两个函数允许延时一段时间再运行函数。比如下面的代码,一
淘宝网有很多的专用工具,有一些店家很有可能从未听过或是是沒有应用过。因此,我今天要跟大伙儿讲的是淘宝网店探案这款软件专用工具。例如,淘宝网店探案是做什么的?淘宝
相关阅读:JavaScript事件学习小结(五)js中事件类型之鼠标事件JavaScript事件学习小结(一)事件流javaScript事件学习小结(四)eve
相关阅读:JavaScript事件学习小结(五)js中事件类型之鼠标事件JavaScript事件学习小结(一)事件流javaScript事件学习小结(四)eve