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


    你是否写过或见到过这样的代码
    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方法
    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,可以验证以下的代码
    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与数据真实键值不对应,还是根据循环来处理
    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 对象”的错误,错误事例
       XXX.apply(window,{0:'a',1:'b',length:2})// ERROR Function.prototype.apply: 缺少 Array 或 arguments 对象
    

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

  • 相关阅读:
    Python入门篇-解析式、生成器
    使用Kerberos进行Hadoop认证
    Python标准库-datatime和time
    使用Cloudera Manager部署HUE
    使用Cloudera Manager部署oozie
    使用Cloudera Manager部署Spark服务
    HDFS重启集群导致数据损坏,使用fsck命令修复过程
    关系型数据的收集
    使用Cloudera Manager搭建Kudu环境
    分布式结构化存储系统-Kudu简介
  • 原文地址:https://www.cnblogs.com/henryli/p/3654159.html
Copyright © 2020-2023  润新知