why does array slice convert javascript arguments to array(为什么数组切片将javascript参数转换为数组)
问题描述
为什么将切片方法应用于javascript arguments 值如下Array.prototype.slice.call(arguments) 将其转换为数组?如果在数组上使用 slice,并且 arguments 不是数组,那么它是如何工作的?将 slice 应用于参数是否只是一种特殊情况?
Why does applying the slice method to the javascript arguments value as follows Array.prototype.slice.call(arguments) convert it to an array? If slice is used on arrays, and arguments is not an array, then how does this work? Is it just a special case when slice is applied to arguments?
推荐答案
来自 EcmaScript 规范Array.prototype.slice:
注意 slice 函数是故意通用的;它不要求其 this 值是 Array 对象.因此,它可以转移到其他类型的对象中用作方法.slice 函数能否成功应用于宿主对象取决于实现.
NOTE The
slicefunction is intentionally generic; it does not require that itsthisvalue be an Array object. Therefore it can be transferred to other kinds of objects for use as a method. Whether theslicefunction can be applied successfully to a host object is implementation-dependent.
因此,slice 适用于每个具有 length 属性的对象(如 Arguments 对象).即使对于那些不这样做的人,它也只会返回一个空数组.
And so, slice works on every object that has a length property (like Arguments objects). And even for those that do not, it then just returns an empty array.
这篇关于为什么数组切片将javascript参数转换为数组的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么数组切片将javascript参数转换为数组
基础教程推荐
- 检查 HTML5 拖放文件类型 2022-01-01
- Bokeh Div文本对齐 2022-01-01
- 即使用户允许,Gmail 也会隐藏外部电子邮件图片 2022-01-01
- 原生拖动事件后如何获取 mouseup 事件? 2022-01-01
- 在 contenteditable 中精确拖放 2022-01-01
- npm start 错误与 create-react-app 2022-01-01
- 如何添加到目前为止的天数? 2022-01-01
- fetch 是否支持原生多文件上传? 2022-01-01
- Fabric JS绘制具有活动形状的多边形 2022-01-01
- Bootstrap 模态出现在背景下 2022-01-01
