Справка: Практическое использование крышек
На практике замыкания могут создавать элегантные конструкции, позволяющие настраивать различные вычисления, отложенные вызовы, обратные вызовы, создавать инкапсулированную область видимости и т. Д.
Пример метода сортировки массивов, который принимает в качестве аргумента функцию условия сортировки:
[1, 2, 3].sort(function (a, b) {
... // sort conditions
});
Отображение функционалов в качестве метода отображения массивов, который отображает новый массив по условию функционального аргумента:
[1, 2, 3].map(function (element) {
return element * 2;
}); // [2, 4, 6]
Часто удобно реализовать функции поиска с использованием функциональных аргументов, определяющих практически неограниченные условия поиска:
someCollection.find(function (element) {
return element.someProperty == 'searchCondition';
});
Также мы можем отметить применение функционалов как, например, метода forEach, который применяет функцию к массиву элементов:
[1, 2, 3].forEach(function (element) {
if (element % 2 != 0) {
alert(element);
}
}); // 1, 3
Функция применяется к аргументам (к списку аргументов - в применении и к позиционированным аргументам - в вызове):
(function () {
alert([].join.call(arguments, ';')); // 1;2;3
}).apply(this, [1, 2, 3]);
Отложенные звонки:
var a = 10;
setTimeout(function () {
alert(a); // 10, after one second
}, 1000);
Функции обратного вызова:
var x = 10;
// only for example
xmlHttpRequestObject.onreadystatechange = function () {
// callback, which will be called deferral ,
// when data will be ready;
// variable "x" here is available,
// regardless that context in which,
// it was created already finished
alert(x); // 10
};
Создание инкапсулированной области видимости с целью сокрытия вспомогательных объектов:
var foo = {};
(function (object) {
var x = 10;
object.getX = function _getX() {
return x;
};
})(foo);
alert(foo.getX());// get closured "x" – 10