javascript – 复制arguments对象的子集,而不使用显式循环
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 复制arguments对象的子集,而不使用显式循环,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含938字,纯文字阅读大概需要2分钟。
内容图文
![javascript – 复制arguments对象的子集,而不使用显式循环](/upload/InfoBanner/zyjiaocheng/760/536de09e555a4d8c81283196d831f04b.jpg)
我有一个JavaScript函数,它需要两个必需的参数,然后任意多个可选参数.
function myFunction(required1, required2) {
var more = [];
for (var i = 2; i < arguments.length; ++i)
more.push(arguments[i]);
// ...
}
现在,我喜欢通过我的所有代码强制执行一致的样式.由于我的网站使用jQuery,而jQuery喜欢使用$.each和$.map而不是显式循环,我想摆脱myFunction中的显式循环.但是,我不能使用$.each或$.map,因为我不想复制整个参数列表,以免我执行以下操作:
var more = $.map(arguments, function(argument, index) {
return (index < 2) ? null : [argument];
});
当然,这是一个非常糟糕的主意,因为测试是否索引<每次迭代都不需要2次. 我真的希望能够使用标准函数将参数对象的子集提取到新数组中.但是,因为参数不是数组,所以我无法对其进行切片. 有没有其他方法我可以提取到一个数组所有参数,但前两个,没有使用显式循环,并没有失去效率?
解决方法:
使用slice方法:
var optional_arguments = Array.prototype.slice.call(arguments, 2);
我们必须从Array.prototype中调用它,因为即使参数是类似数组的,它实际上也没有切片方法.
内容总结
以上是互联网集市为您收集整理的javascript – 复制arguments对象的子集,而不使用显式循环全部内容,希望文章能够帮你解决javascript – 复制arguments对象的子集,而不使用显式循环所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。