javascript createAdder函數功能與使用說明

來源:互聯網
上載者:User

英文原文
createAdder(x) is a function that returns a function. In JavaScript, functions are first-class objects: they can be passed to other functions as arguments and returned from functions as well. In this case, the function returned is itself a function that takes an argument and adds something to it.

Here’s the magic: the function returned by createAdder() is a closure. It “remembers” the environment in which it was created. If you pass createAdder the integer 3, you get back a function that will add 3 to its argument. If you pass 4, you get back a function that adds 4. The addThree and addFour functions in the above example are created in this way.

Let’s take another look at the addLoadEvent function. It takes as its argument a callback function which you wish to be executed once the page has loaded. There follow two cases: in the first case, window.onload does not already have a function assigned to it, so the function simply assigns the callback to window.onload. The second case is where the closure comes in: window.onload has already had something assigned to it. This previously assigned function is first saved in a variable called oldonload. Then a brand new function is created which first executes oldonload, then executes the new callback function. This new function is assigned to window.onload. Thanks to the magical property of closures, it will “remember” what the initial onload function was. Further more, you can call the addLoadEvent function multiple times with different arguments and it will build up a chain of functions, making sure that everything will be executed when the page loads no matter how many callbacks you have added.

Closures are a very powerful language feature but can take some getting used to. This article on Wikipedia provides more in-depth coverage.

中文翻譯:有更好的可以留言。大體意思差不多了

createAdder(x)是一個函數,返回一個函數。在JavaScript中,函數是第一類對象:另外它們可以被傳遞到其他函數作為參數和函數返回。在這種情況下,函數返回本身就是一個函數接受一個參數,並增加了一些東西。

在這裡,Äôs the magic:由createAdder返回函數()是一個閉包。它,Äúremembers,非盟在建立它的環境。如果傳遞createAdder整數3,你回來一個函數,將增加3至其參數。如果你通過四,你回來一個函數,增加了4。該addThree在上面的例子addFour職能創造這樣的。

讓,星光大道可以再一次看看addLoadEvent功能。這需要將執行一次頁面已載入為一個回呼函數的參數,你的願望。有下列兩種情況:在第一種情況,在window.onload已經沒有分配給它一個函數,因此函數簡單的回調在window.onload分配。第二個案例是在關閉的時候:在window.onload已經有分配給它的東西。這是以前分配的功能首次在一個名為oldonload變數儲存。然後,一個全新的功能是建立的第一個執行oldonload,然後執行新的回呼函數。這一新功能被分配在window.onload。神奇的封鎖財產感謝,它會Äúremember,非盟最初的onload什麼功能。進一步,你可以調用函數的addLoadEvent多次與不同的參數,它會建立一個職能鏈,確保一切都將在頁面載入時執行,不管你有多少回調增加。

閉包是一個非常強大的語言功能,但可能需要一些時間來適應。這種對維基百科的文章提供了更深入的報道。

核心代碼複製代碼 代碼如下:function createAdder(x) {
return function(y) {
return y + x;
}
}
addThree = createAdder(3);
addFour = createAdder(4);
document.write('10 + 3 is ' + addThree(10) + '<BR>');
document.write('10 + 4 is ' + addFour(10));
document.write('-10 + 4 is ' + addFour(-10));

示範代碼:
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.