一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

將函數(shù)的實(shí)際參數(shù)轉(zhuǎn)換成數(shù)組的方法

值得慶幸的是,我們可以通過(guò)數(shù)組的 slice 方法將 arguments 對(duì)象轉(zhuǎn)換成真正的數(shù)組:
var args = Array.prototype.slice.call(arguments);
對(duì)于slice 方法,ECMAScript 262 中 15.4.4.10 Array.prototype.slice (start, end) 章節(jié)有備注:
復(fù)制代碼 代碼如下:
The slice function is intentionally generic; it does not require that its this value be an Array object. Therefore it can be transferred to other kinds of objects for use as a method. Whether the slice function can be applied successfully to a host object is implementation-dependent.

《Pro JavaScript Design Patterns》(《JavaScript 設(shè)計(jì)模式》)的作者 Dustin Diaz 曾指出:
復(fù)制代碼 代碼如下:
instead of…
var args = Array.prototype.slice.call(arguments); // 懌飛注:下稱(chēng)方法一
do this…
var args = [].slice.call(arguments, 0); // 懌飛注:下稱(chēng)方法二

但二者的性能差異真的存在嗎?經(jīng)過(guò)個(gè)人簡(jiǎn)單測(cè)試發(fā)現(xiàn):

在 arguments.length 較小的時(shí)候,方法二性能上稍有一點(diǎn)點(diǎn)優(yōu)勢(shì),而在arguments.length 較大的時(shí)候,方法一卻又稍有優(yōu)勢(shì)。

最后附上方法三,最老土的方式:
復(fù)制代碼 代碼如下:
var args = [];
for (var i = 1; i < arguments.length; i++) {
args.push(arguments[i]);
}

不過(guò)對(duì)于平常來(lái)說(shuō),個(gè)人建議還是使用第二種方法,但任何解決方案,沒(méi)有最好的,只有最合適:
復(fù)制代碼 代碼如下:
var args = [].slice.call(arguments, 0);
理由有二:

一般的函數(shù)的 arguments.length 都在 10 以?xún)?nèi),方法二有優(yōu)勢(shì);
方法二的代碼量上也比第一種少,至少可以減小一點(diǎn)字節(jié) ^^

如何將 NodeList (比如:document.getElementsByTagName('div'))轉(zhuǎn)換成數(shù)組呢?

解決方案簡(jiǎn)單如下:
復(fù)制代碼 代碼如下:
function nodeListToArray(nodes){
var arr, length;
try {
// works in every browser except IE
arr = [].slice.call(nodes);
return arr;
} catch(err){
// slower, but works in IE
arr = [];
length = nodes.length;
for(var i = 0; i < length; i++){
arr.push(nodes[i]);
}
return arr;
}
}

為什么 IE 中 NodeList 不可以使用 [].slice.call(nodes) 方法轉(zhuǎn)換呢?
In InterNET Explorer it throws an error that it can't run Array.prototype.slice.call(nodes) because a DOM NodeList is not a JavaScript object.

JavaScript技術(shù)將函數(shù)的實(shí)際參數(shù)轉(zhuǎn)換成數(shù)組的方法,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 一级做a爰片久久毛片16 | 国产精品午夜免费观看网站 | 婷婷五月在线视频 | 欧美日韩国产一区三区 | 亚州va| 日韩av成人| 久久中文字幕免费 | 国产成人精品亚洲日本在线 | 国产精品久久久久久吹潮 | 午夜在线视频免费观看 | 91精品欧美 | 久草色视频 | 欧美透逼视频 | 国产第一第二第三第四第五 | 成人免费观看在线网址 | 色哟哟哟| 精品久久久久久影院免费 | 热re66久久精品国产99re | 四虎现在的网址入口2022 | 中国精品视频一区二区三区 | 欧美视频久久久 | 午夜国产在线视频 | 69视频免费观看 | 国产黄色片在线播放 | 欧洲a老妇女黄大片 | 国内自拍网红在线综合 | 人成精品视频三区二区一区 | www.最色| 婷婷色在线视频 | 91最新网站 | 精品久久久中文字幕一区 | 色噜噜狠狠先锋影音久久 | 天天爽天天爽 | 四虎影院色 | 国产大片视频免费观看 | 久久久久久久网站 | 免费一级乱子伦片 | 国内精品手机在线观看视频 | 美女视频黄是免费 | 激情五月社区 | 在线观看免费福利 |