色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

將函數的實際參數轉換成數組的方法

值得慶幸的是,我們可以通過數組的 slice 方法將 arguments 對象轉換成真正的數組:
var args = Array.prototype.slice.call(arguments);
對于slice 方法,ECMAScript 262 中 15.4.4.10 Array.prototype.slice (start, end) 章節有備注:
復制代碼 代碼如下:
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 設計模式》)的作者 Dustin Diaz 曾指出:
復制代碼 代碼如下:
instead of…
var args = Array.prototype.slice.call(arguments); // 懌飛注:下稱方法一
do this…
var args = [].slice.call(arguments, 0); // 懌飛注:下稱方法二

但二者的性能差異真的存在嗎?經過個人簡單測試發現:

在 arguments.length 較小的時候,方法二性能上稍有一點點優勢,而在arguments.length 較大的時候,方法一卻又稍有優勢。

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

不過對于平常來說,個人建議還是使用第二種方法,但任何解決方案,沒有最好的,只有最合適:
復制代碼 代碼如下:
var args = [].slice.call(arguments, 0);
理由有二:

一般的函數的 arguments.length 都在 10 以內,方法二有優勢;
方法二的代碼量上也比第一種少,至少可以減小一點字節 ^^

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

解決方案簡單如下:
復制代碼 代碼如下:
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) 方法轉換呢?
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技術將函數的實際參數轉換成數組的方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 襄汾县| 正安县| 开封市| 黄梅县| 贵德县| 东乌珠穆沁旗| 合肥市| 通河县| 东阳市| 佳木斯市| 南投市| 茌平县| 依安县| 榆中县| 瑞安市| 镇坪县| 义乌市| 靖江市| 和政县| 巴彦县| 镇坪县| 遵义市| 祁阳县| 文水县| 富民县| 兖州市| 民和| 平阳县| 伽师县| 海城市| 江川县| 江城| 寿宁县| 南木林县| 北宁市| 武乡县| 灵石县| 金昌市| 荣成市| 清水河县| 尼木县|