apply方法
apply是所有函数都有的方法.它的签名如下:
func.apply(thisValue, [arg1, arg2, ...])
如果不考虑thisValue的影响,上面的调用等同于:
func(arg1, arg2, ...)
也就是说,apply允许我们将一个数组"解开"成为一个个的参数再传递给调用函数.让我们分别看看apply使用中的三个技巧.
技巧1: 将一个数组传递给一个不接受数组作为参数的函数 JavaScript中没有返回一个数组中最大值的函数.但是,有一个函数Math.max可以返回任意多个数值类型的参数中的最大值.再配合apply,我们可以实现我们的目的:
复制代码 代码如下:
> Math.max.apply(null, [10, -1, 5])
10
译者注:注意Math.max方法的参数中只要有一个值被转为NaN,则该方法直接返回NaN
复制代码 代码如下:
>Math.max(1,null) //相当于Math.max(1,0)
1
>Math.max(1,undefinded) //相当于Math.max(1,NaN)
NaN
>Math.max(0,-0) //正零比负零大,和==不同
0
>Math.max(-0,-1) //负零比-1大
-0
技巧2: 填补稀疏数组 数组中的缝隙
这里提醒一下读者:在JavaScript中,一个数组就是一个数字到值的映射.所以如果某个索引处缺失了一个元素(一条缝隙)和某个元素的值为undefined,是两种不同的情况.前者在被Array.prototype中的相关方法(forEach, map, 等.)遍历时,会跳过那些缺失的元素,而后者不会:
复制代码 代码如下:
> ["a",,"b"].forEach(function (x) { console.log(x) })
a
> ["a",undefined,"b"].forEach(function (x) { console.log(x) })
a
undefined
译者注:这里作者说"数组就是一个数字到值的映射",严格意义上是不对的,正确的说法是"数组就是一个字符串到值的映射".下面是证据:
复制代码 代码如下:
>for (i in ["a", "b"]) {
console.log(typeof i) //数组的索引实际上是个字符串
}
"string"
"string"
>["a", "b"].forEach(function (x, i) {
console.log(typeof i) //这里的i实际上不是索引,只是个数字类型的累加器
})
"number"
"number"
你可以使用in运算符来检测数组中是否有缝隙.
复制代码 代码如下:
> 1 in ["a",,"b"]
false
> 1 in ["a", undefined, "b"]
true
译者注:这里之所以用1可以,是因为in运算符会把1转换成"1".
你过你尝试读取这个缝隙的值,会返回undefined,和实际的undefined元素是一样.
复制代码 代码如下:
> ["a",,"b"][1]
undefined
> ["a", undefined, "b"][1]
undefined
译者注:[1]也会被转换成["1"]
填补缝隙 apply配合Array(这里不需要加new)使用,可以将数组中的缝隙填补为undefined元素:
复制代码 代码如下:
> Array.apply(null, ["a",,"b"])
[ 'a', undefined, 'b' ]
这都是因为apply不会忽略数组中的缝隙,会把缝隙作为undefined参数传递给函数:
复制代码 代码如下:
> function returnArgs() { return [].slice.call(arguments) }
> returnArgs.apply(null, ["a",,"b"])
[ 'a', undefined, 'b' ]
但需要注意的是,如果Array方法接收到的参数是一个单独的数字,则会把这个参数当成数组长度,返回一个新数组:
复制代码 代码如下:
> Array.apply(null, [ 3 ])
[ , , ]
因此,最靠谱的方法是写一个这样的函数来做这种工作:
复制代码 代码如下:
function fillHoles(arr) {
var result = [];
for(var i=0; i < arr.length; i++) {
result[i] = arr[i];
}
return result;
}
执行:
复制代码 代码如下:
> fillHoles(["a",,"b"])
[ 'a', undefined, 'b' ]
Underscore中的_.compact函数会移除数组中的所有假值,包括缝隙:
复制代码 代码如下:
> _.compact(["a",,"b"])
[ 'a', 'b' ]
> _.compact(["a", undefined, "b"])
[ 'a', 'b' ]
> _.compact(["a", false, "b"])
[ 'a', 'b' ]
技巧3: 扁平化数组
任务:将一个包含多个数组元素的数组转换为一个一阶数组.我们利用apply解包数组的能力配合concat来做这件事:
复制代码 代码如下:
> Array.prototype.concat.apply([], [["a"], ["b"]])
[ 'a', 'b' ]
混合非数组类型的元素也可以:
复制代码 代码如下:
> Array.prototype.concat.apply([], [["a"], "b"])
[ 'a', 'b' ]
apply方法的thisValue必须指定为[],因为concat是一个数组的方法,不是一个独立的函数.这种写法的限制是最多只能扁平化二阶数组:
复制代码 代码如下:
> Array.prototype.concat.apply([], [[["a"]], ["b"]])
[ [ 'a' ], 'b' ]
所以你应该考虑一个替代方案.比如Underscore中的_.flatten函数就可以处理任意层数的嵌套数组:
复制代码 代码如下:
> _.flatten([[["a"]], ["b"]])
[ 'a', 'b' ]
参考
JavaScript: sparse arrays vs. dense arrays
ECMAScript.next: Array.from() and Array.of()
相关推荐:
SEO模板:提升网站排名,助你快速抢占搜索引擎流量高地,选择seo职业缺点
seo资源是什么意思,seo资源怎么打开 ,梅州ai自动插件加工
SEO优化是做什么的?让你的网站流量飙升的秘密武器,乳腺癌ai作用机理
ChatGPT桌面版无法加载?快速解决方案及常见问题解析,ai媚眼
SEO课:让你从小白变成搜索引擎优化高手,推广自媒体营销计划
“新热度”:引领潮流的力量,如何趋势的脉搏,浙江通用网站建设特点
SEO要素:优化网站排名的关键因素全解析,棒球大联盟营销推广文案
WPQQ-开启数字时代的智能连接新纪元,杭州网站推广厂家电话
亚马逊的seo是什么阿,亚马逊seo项目 ,中考用ai写作会判0分吗
“新关键词”开启智慧营销新篇章,助力品牌突围,自己如何做网站seo
ChatGPT崩了?用户称打开是一片空白,真相竟然如此!,zzz*明星AI换脸
seo黑帽是什么,列举几种seo黑帽行为 ,穿老款的ai丢人吗
ChatGPT网页打不开?快来看看这些解决办法,轻松恢复正常访问!,ai金色包装
seo需要做些什么,做seo的 ,超级ai地图
文章AI生成:让创作变得更简单、更高效!
SEO领先-如何借助SEO技术让您的网站脱颖而出,seo是黑客吗
SEO可以帮助网站在搜索引擎中获得较高的排名-助力企业数字化转型的关键,赵立新AI换脸图片对比
为什么要年前做SEO,企业为什么做seo推广 ,云南ai大数据公司
SEO做网站点击:提升网站流量的关键策略,国内ai写作论文
亚马逊中什么是seo,亚马逊sop ,ai临摹中国名画
什么是seo网站推广,什么是seo网站推广 ,ai酷男人
Bing学术搜索结果不显示时间?如何解决这一问题,提升学术研究效率!,ai怎么参考线
ChatGPT维护-智能时代的数字助手,如何让你的工作更高效,ai智能救援
seo独立站是什么,独立站推广是什么 ,ai曲线笔刷扩展
AI免费试用不需要登录:体验智能科技的魅力,轻松开启未来,华为ai身材
优化文字,让表达更精准:提升写作效率的关键,个人网站建设外包
什么是seo手段,seo的具体手段 ,中国ai 企业
AI人工智能文章生成平台,释放创作无限可能
优化投入,让企业更具竞争力,怎样推广营销方案
seo线索收集是什么,seo线索收集是什么意思 ,ai生活ai童童
怎样利用AI写文章,轻松提升写作效率
文字写作AI生成工具:让创作更简单、更高效
seo软件工具,seo软件是什么 ,AI妆容
如何通过AI写文章,轻松提高写作效率与质量
为什么“未备案域名”会成为互联网行业中的重要问题?,江干区seo优化价格
SEO合作:让你的网站在搜索引擎中脱颖而出,惠州抖音seo策划公司
揭开“好的AI软件”背后的秘密:让生活和工作更智能的利器
SEO搜外:全球搜索引擎优化的秘密武器,如何选择网站建设类型呢
SEO占位:如何在竞争激烈的市场中占得先机?,梁平区省心全网营销推广
Bing搜索的注意事项-提高搜索效率与准确性,轻松获取所需信息,最近ai写作软件推荐
什么是seo运营,什么是seo营销 ,ai绘画沙地
ChatGPT为什么访问不了?全面解析及解决方案,ai首页设计
ChatGPTDNS出问题?如何快速解决并保障网络畅通,墨镜ai照片
ChatGPT页面无法下拉?禁用浏览器扩展,轻松解决!,imba 1.6 ai
ChatGPT3.5需要登录使用吗?AI使用的真相!,电脑版写作ai推荐怎么关闭
ChatGPT全球宕机:人工智能的崩塌与未来的挑战,中国ai和美国ai教父
优方法-高效生活与工作的秘密武器,钻石营销推广方案
SEO收集:如何通过有效数据收集提升网站排名,鞍山商城网站建设报价
什么是seo网络推广seo顾问,seo网络推广员 ,ai20170119
为什么选择收录网站是企业在线营销的必备策略,全网营销与推广