Книга: JavaScript. Подробное руководство, 6-е издание
8.2.1. Вызов функций
8.2.1. Вызов функций
Вызов функций как функций или как методов, выполняется с помощью выражения вызова (раздел 4.5). Выражение вызова состоит из выражения обращения к функции, которое возвращает объект функции, и следующими за ним круглыми скобками со списком из нуля или более выражений-аргументов, разделенных запятыми, внутри. Если выражение обращения к функции является выражением обращения к свойству - если функция является свойством объекта или элементом массива - тогда выражение вызова является выражением вызова метода. Этот случай будет описан ниже. В следующем фрагменте демонстрируется несколько примеров выражений вызова обычных функций:
printprops({х:1});
var total = distance(0,0,2,1) + distanced, 1,3, 5);
var probability = factorial(5)/factorial(13);
При вызове функции вычисляются все выражения-аргументы (указанные между скобками), и полученные значения используются в качестве аргументов функции. Эти значения присваиваются параметрам, имена которых перечислены в определении функции. В теле функции выражения обращений к параметрам возвращают значения соответствующих аргументов.
При вызове обычной функции возвращаемое функцией значение становится значением выражения вызова. Если возврат из функции происходит по достижении ее конца интерпретатором, возвращается значение undefined
. Если возврат из функции происходит в результате выполнения инструкции return
, возвращается значение выражения, следующего за инструкцией return
, или undefined
, если инструкция return
не имеет выражения.
При вызове функции в ECMAScript 3 и в нестрогом режиме ECMAScript 5 контекстом вызова (значением this
) является глобальный объект. Однако в строгом режиме контекстом вызова является значение undefined
.
Функции, которые предназначались для использования в виде простых функций, обычно вообще не используют ключевое слово this
. Впрочем, его можно использовать, чтобы определить, не выполняется ли функция в строгом режиме:
// Определение и вызов функции, которая выясняет действующий режим работы,
var strict = (function() { return !this; }());
Составление цепочек вызовов методов
Когда методы возвращают объекты, появляется возможность использовать значение, возвращаемое одним методом, как часть последующих вызовов. Это позволяет создавать последовательности («цепочки», или «каскады») вызовов методов в одном выражении. При работе с библиотекой jQuery
(глава 19), например, часто можно встретить такие инструкции:
// Отыскать все заголовки, отобразить их в значения атрибутов id,
// преобразовать в массив и отсортировать
$( ":header").map(function() { return this.id )).get().sort();
Если вы пишете метод, не имеющий собственного возвращаемого значения, подумайте о возможности возвращать из него значение this. Если неуклонно следовать этому правилу при разработке своего API, появится возможность использовать стиль программирования, известный как составление цепочек из методов,[12]
когда обращение к имени метода выполняется один раз, а затем может следовать множество вызовов его методов:
shape.setX(100).setY(100).setSize(50).setOutline("red").setFill("blue").draw();
He путайте цепочки вызовов методов с цепочками конструкторов, которые описываются в разделе 9.7.2.
- Системные вызовы и драйверы устройств
- Вызовы функций
- Семейство функций exec()
- 3.2.3. Системные вызовы: brk() и sbrk()
- Вызов системных функций и стандартных диалоговых окон оболочки Windows
- Вызов API-функций
- Преобразования типов при вызовах функций
- 6.4.2 Взаимодействие с операционной системой через вызовы системных функций
- 8.2. Вызов функций
- 3.4.5. Вызов функций, передача параметров, возврат полученных значений
- Средства, отслеживающие вызовы функций
- Вызов процедур и функций