英文文
createAdder(x)는 함수를 반환하는 함수입니다. JavaScript에서 함수는 일급 개체입니다. 다른 함수에 인수로 전달될 수도 있고 함수에서 반환될 수도 있습니다. 이 경우 반환된 함수 자체는 인수를 취하고 여기에 무언가를 추가하는 함수입니다.
여기에 마법이 있습니다. createAdder()가 반환하는 함수는 클로저입니다. 그것은 자신이 만들어졌던 환경을 '기억'합니다. createAdder에 정수 3을 전달하면 인수에 3을 더하는 함수가 반환됩니다. 4를 전달하면 4를 더하는 함수가 반환됩니다. 위 예제의 addThree 및 addFour 함수는 이런 방식으로 생성됩니다.
addLoadEvent 함수를 다시 살펴보겠습니다. 페이지가 로드되면 실행하려는 콜백 함수를 인수로 사용합니다. 다음 두 가지 경우가 있습니다. 첫 번째 경우, window.onload에는 아직 함수가 할당되어 있지 않으므로 함수는 단순히 콜백을 window.onload에 할당합니다. 두 번째 경우는 클로저가 들어오는 경우입니다. window.onload에는 이미 무언가가 할당되어 있습니다. 이전에 할당된 이 기능은 먼저 oldonload라는 변수에 저장됩니다. 그런 다음 먼저 oldonload를 실행한 다음 새 콜백 함수를 실행하는 새로운 함수가 생성됩니다. 이 새로운 기능은 window.onload에 할당됩니다. 클로저의 마법 같은 속성 덕분에 클로저는 초기 온로드 기능이 무엇인지 '기억'할 것입니다. 또한, 다양한 인수를 사용하여 addLoadEvent 함수를 여러 번 호출할 수 있으며 함수 체인을 구축하여 추가한 콜백 수에 관계없이 페이지가 로드될 때 모든 것이 실행되도록 합니다.
클로저는 매우 강력한 언어 기능이지만 익숙해지는 데 시간이 걸릴 수 있습니다. Wikipedia의 이 기사에서는 더 자세한 내용을 다루고 있습니다.
中文翻译:有更好的可以留言。大体意思差不多了createAdder(x)是一个函数,返回一个函数。재JavaScript中,函数是第一类对象:另外它们可以被传递到其他函数数作为参数 and函数返回。 在这种情况下 ,函数返回本身就是一个函数接受一个参数,并增加了一些东西。
여기에서, 이것이 바로 마법입니다.增加3至其参数。如果你通过4,你回来一个函数,增加了4。该addThreein上side例子addFour职能创造这样的。
让,star光大道可以再一次看看addLoadEvent功能。这需要将执行一次页면已加载为一个回调函数的参数,你的愿望。有下列两种情况 : 에서window.onload에서已经没有分配给它一个函数,因此函数简单的回调inwindow.onload分配。第二个案例是지금关闭당신의 시간은 다음과 같습니다.个执行oldonload,然后执行新的回调函数。这一new功能被分配에서window.onload。신중한封锁财产感谢,它会äú기억하세요,비盟最初的onload什么功能。进一步,你可以调用函数的LoadEvent는 더 이상 서로 같지 않습니다.职能链,确保一切city将在页face加载时执行,不管你有多少回调增加。
闭包是一个不常强大的语言功能,但可能需要一些时间来适应。这种对维基百科的文章提供了更深入的报道。
核心代码
function createAdder(x) {
return function(y) {
return y x;
}
}
addThree = createAdder(3);
addFour = createAdder(4);
document.write('10 3은 ' addThree(10) '
');
document.write('10 4는 ' addFour(10));
document.write('-10 4는 ' addFour(-10));
演示代码: