国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript奇異的arguments分析

2019-11-21 00:11:33
字體:
供稿:網(wǎng)友
在每個函數(shù)中,都有個名為 arguments 的變量,它以類似數(shù)組的形式保存了當前調(diào)用的參數(shù)。而它實際上并不是個數(shù)組,使用 typeof arguments 語句嘗試會返回“object”(對象),所以它不能像 Array 一樣使用 push 和 pop 等方法。即便如此,仍然可以使用下標以及長度屬性(length)獲取它的值。

編寫靈活的函數(shù)
雖看起來名不經(jīng)傳,但的確 arguments 是非常有用的對象。比如,你可以讓函數(shù)處理不定數(shù)目的參數(shù)。在 Dean Edwards 寫的 base2 庫中,有個叫 format 的函數(shù)充分發(fā)揮了這一特性:
復制代碼 代碼如下:

function format(string) {
var args = arguments;
var pattern = new RegExp("%([1-" + arguments.length + "])", "g");
return String(string).replace(pattern, function(match, index) {
return args[index];
});
};

這個函數(shù)實現(xiàn)了模板替換,你可以在要動態(tài)替換的地方使用 %1 到 %9 標記,然后其余的參數(shù)就會依次替換這些地方。例如:

format("And the %1 want to know whose %2 you %3", "papers", "shirt", "wear");上面的腳本就會返回

"And the papers want to know whose shirt you wear" 。在這里需要注意的是,即便在 format 函數(shù)定義中,我們僅定義了個名為 string 的參數(shù)。而 Javascript 不管函數(shù)自身定義的參數(shù)數(shù)量,它都允許我們向一個函數(shù)傳遞任意數(shù)量的參數(shù),并將這些參數(shù)值保存到被調(diào)用函數(shù)的 arguments 對象中。

轉(zhuǎn)換成實際數(shù)組
雖然 arguments 對象并不是真正意義上的 Javascript 數(shù)組,但是我們可以使用數(shù)組的 slice 方法將其轉(zhuǎn)換成數(shù)組,類似下面的代碼
復制代碼 代碼如下:

var args = Array.prototype.slice.call(arguments);

這樣,數(shù)組變量 args 包含了所有 arguments 對象包含的值。

創(chuàng)建預置參數(shù)的函數(shù)
使用 arguments 對象能夠簡短我們編寫的 Javascript 代碼量。下面有個名為 makeFunc 的函數(shù),它根據(jù)你提供的函數(shù)名稱以及其他任意數(shù)目的參數(shù),然后返回個匿名函數(shù)。此匿名函數(shù)被調(diào)用時,合并的原先被調(diào)用的參數(shù),并交給指定的函數(shù)運行然后返回其返回值。
復制代碼 代碼如下:

function makeFunc() {
var args = Array.prototype.slice.call(arguments);
var func = args.shift();
return function() {
return func.apply(null, args.concat(Array.prototype.slice.call(arguments)));
};
}

makeFunc 的第一個參數(shù)指定需要調(diào)用的函數(shù)名稱(是的,在這個簡單的例子中沒有錯誤檢查),獲取以后從 args 中刪除。makeFunc 返回一個匿名函數(shù),它使用函數(shù)對象的(Function Object)apply 方法調(diào)用指定的函數(shù)。

apply 方法的第一個參數(shù)指定了作用域,基本上的作用域是被調(diào)用的函數(shù)。不過這樣在這個例子中看起來會有點復雜,所以我們將其設(shè)定成 null ;其第二個參數(shù)是個數(shù)組,它指定了其調(diào)用函數(shù)的參數(shù)。makeFunc 轉(zhuǎn)換其自身的 arguments 并連接匿名函數(shù)的 arguments,然后傳遞到被調(diào)用的函數(shù)。

有種情況就是總是要有個輸出的模板是相同的,為了節(jié)省每次是使用上面提到的 format 函數(shù)并指定重復的參數(shù),我們可以使用 makeFunc 這個工具。它將返回一個匿名函數(shù),并自動生成已經(jīng)指定模板后的內(nèi)容:
復制代碼 代碼如下:

var majorTom = makeFunc(format, "This is Major Tom to ground control. I'm %1.");

你可以像這樣重復指定 majorTom 函數(shù):
復制代碼 代碼如下:

majorTom("stepping through the door");
majorTom("floating in a most peculiar way");

那么當每次調(diào)用 majorTom 函數(shù)時,它都會使用第一個指定的參數(shù)填寫已經(jīng)指定的模板。例如上述的代碼返回:
復制代碼 代碼如下:

"This is Major Tom to ground control. I'm stepping through the door."
"This is Major Tom to ground control. I'm floating in a most peculiar way."

自引用的函數(shù)
您可能會認為這很酷,先別急著高興,后面還有個更大的驚喜。它(arguments)還有個其他非常有用的屬性:callee 。arguments.callee 包含了當前調(diào)用函數(shù)的被引用對象。那么我們?nèi)绾问褂眠@玩意做些的事情?arguments.callee 是個非常有用的調(diào)用自身的匿名函數(shù)。

下面有個名為 repeat 的函數(shù),它的參數(shù)需要個函數(shù)引用和兩個數(shù)字。第一個數(shù)字表示運行的次數(shù),而第二個函數(shù)定義運行的間隔時間(毫秒為單位)。下面是相關(guān)的代碼:
復制代碼 代碼如下:

function repeat(fn, times, delay) {
return function() {
if(times-- > 0) {
fn.apply(null, arguments);
var args = Array.prototype.slice.call(arguments);
var self = arguments.callee;
setTimeout(function(){self.apply(null,args)}, delay);
}
};
}

repeat 函數(shù)使用 arguments.callee 獲得當前引用,保存到 self 變量后,返回個匿名函數(shù)重新運行原本被調(diào)用的函數(shù)。最后使用 setTimeout 以及配合個匿名函數(shù)實現(xiàn)延遲執(zhí)行。

作為個簡單的說明,比如會在通常的腳本中,編寫下面的提供個字符串并彈出個警告框的簡單函數(shù):
復制代碼 代碼如下:

function comms(s) {
alert(s);
}

好了,后來我改變了我的想法。我想編寫個“特殊版本”的函數(shù),它會重復三次運行每次間隔兩秒。那么使用我的 repeat 函數(shù),就可以像這樣做到:
復制代碼 代碼如下:

var somethingWrong = repeat(comms, 3, 2000);
somethingWrong("Can you hear me, major tom?");

結(jié)果就猶如預期的那樣,彈出了三次警告框每次延時兩秒。

最后,arguments 即便不會經(jīng)常被用到,甚至顯得有些詭異,但是它上述的那些驚艷的功能(不僅僅是這些!)值得你去了解它。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 容城县| 宜春市| 石门县| 竹溪县| 阳曲县| 凌源市| 缙云县| 日喀则市| 克拉玛依市| 北京市| 米泉市| 宜章县| 离岛区| 云和县| 百色市| 宁蒗| 怀集县| 棋牌| 安福县| 西畴县| 秦皇岛市| 凤台县| 恩平市| 墨玉县| 杭州市| 宣城市| 苍山县| 林州市| 丹巴县| 乌恰县| 乐山市| 犍为县| 洪泽县| 大同市| 西昌市| 兴隆县| 义马市| 太仓市| 镇坪县| 通河县| 库尔勒市|