js中apply(thisArg, [argsArray])的参数与ArrayLike的关系

你是否写过或见到过这样的代码

1
xx.apply(this,slice.call(arguments)) //slice.call转为数组是否多余

一、微软和mdn对参数的介绍
  • msdn上写的是一组参数(A set of arguments to be passed to the function.)
  • mdn写的就很清楚了是“An array-like object”,即类似数组。
二、什么是类数组
  • 具有length,键值为int型,可循环。如jQuery的isArrayLike方法```javascript unction isArraylike( obj ) { var length = obj.length, type = jQuery.type( obj );

    if ( type === "function" || jQuery.isWindow( obj ) ) { return false; } //node if ( obj.nodeType === 1 && length ) { return true; } //是数组||length=0||length为number同时具有length-1的键return type === "array" || length === 0 || typeof length === "number" && length > 0 && ( length - 1 ) in obj; } ```

  • 根据ArrayLike,可以验证以下的代码

1
2
3
console.log.apply(console,{0:‘a‘,1:‘b‘,length:2});// a b 在某些浏览器会报错
console.log.apply(console,document.querySelectorAll(‘div‘));// div div .....
(function(){ console.log.apply(console,arguments)  })(window,[1,2,3]);// window [1,2,3]

  • 若length与数据真实键值不对应,还是根据循环来处理

1
console.log.apply(console,{0:‘a‘,4:‘b‘,b:0,length:5});//a undefined undefined undefined b

三、兼容性?mdn上写了如下

Most browsers, including Chrome 14 and Internet Explorer 9, still do not accept array-like objects and will throw an exception.

  • chrome14 ie9与ie9以下传入object参数会报 “Function.prototype.apply: 缺少 Array 或 arguments 对象”的错误,错误事例
    1
    XXX.apply(window,{0:‘a‘,1:‘b‘,length:2})// ERROR Function.prototype.apply: 缺少 Array 或 arguments 对象

四、对于apply来说,非自定义的ArrayLike,可与忽略toArray这一步操作

js中apply(thisArg, [argsArray])的参数与ArrayLike的关系,,5-wow.com

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。