Строка, определяющая тело функции. Она может содержать любое количество инструкций на языке JavaScript, разделенных точками с запятой, и ссылаться на любые имена аргументов, указанные ранее в конструкторе.
Возвращаемое значение
Вновь созданный объект
Function
. Вызов функции приводит к выполнению JavaScript-кода, составляющего аргумент тело.
Исключения
SyntaxError
Указывает, что в аргументе тело или в одном из аргументов из перечня имена_аргументов имеется
Ссылка на объект Function, вызвавший данную функцию, или null, если функция была вызвана из программного кода верхнего уровня. Признано устаревшим.
length
Число именованных аргументов, указанных при объявлении функции.
prototype
Объект, определяющий свойства и методы конструктора, совместно используемые всеми объектами, созданными с помощью этого конструктора.
Методы
apply
Вызывает функцию как метод указанного объекта, передавая ей указанный массив аргументов.
bind
Возвращает новую функцию, которая вызывает данную как метод указанного объекта с указанными аргументами.
call
Вызывает функцию как метод указанного объекта, передавая ей указанные аргументы.
toString
Возвращает строковое представление функции.
Описание
Функция в языке JavaScript - это фундаментальный тип данных. В главе 8 рассказывается, как определять и использовать функции, а в главе 9 рассматриваются близкие темы, касающиеся методов, конструкторов и свойства prototype функций. Подробности см. в этих главах. Обратите внимание: функциональные объекты могут создаваться с помощью описанного здесь конструктора
Function,
но это неэффективно, поэтому в большинстве случаев предпочтительным способом определения функции является инструкция определения функции или функциональный литерал.
В JavaScript 1.1 и более поздних версиях тело функции автоматически получает локальную переменную по имени
arguments
, которая ссылается на объект
Arguments
. Этот объект представляет собой массив значений, переданных функции в качестве аргументов. Не путайте его с устаревшим свойством
arguments[],
описанным ранее. Подробности см. в статье об объекте
Arguments
.
Function.apply
вызывает функцию как метод объекта
Синтаксис
функция, apply(этот_объект, аргументы)
Аргументы
этот_объект
Объект, к которому должна быть применена функция. В теле функции аргумент этот_объект становится значением ключевого слова this. Если указанный аргумент содержит значение null, используется глобальный объект.
аргументы Массив значений, которые должны передаваться функции в качестве аргументов.
Возвращаемое значение
Значение, возвращаемое при вызове функции.
Исключения
ТуреЕrror
Генерируется, если метод вызывается для объекта, не являющегося функцией, или с аргументом аргументы, не являющимся массивом или объектом Arguments.
Описание
Метод
apply
вызывает указанную функцию, как если бы она была методом объекта, заданного аргументом этот_объект, передавая ей аргументы, которые содержатся в массиве аргументы. Он возвращает значение, возвращаемое функцией. В теле функции ключевое слово this ссылается на объект этот_объект.
Аргумент аргументы должен быть массивом или объектом
Arguments
. Если аргументы должны передаваться функции в виде отдельных аргументов, а не в виде массива, следует использовать вызов
Function.call.
Пример
// Применяет метод Object.toStгing, предлагаемый по умолчанию для объекта,
// переопределяющего его собственной версией метода. Обратите внимание
// на отсутствие аргументов.
Object.prototype.toString.apply(o);
// Вызывает метод Math.maxO, используемый для нахождения максимального элемента
// в массиве. Обратите внимание: в этом случае первый аргумент не имеет значения,
var data = [1,2,3,4,5,6,7,8];
Math.max.apply(null, data);
См. также
Function. call
Function.arguments[] (устарело)
аргументы, переданные функции
Синтаксис
функция.arguments [і]
функция.arguments, length
Описание
Свойство
arguments
объекта
Function
представляет собой массив аргументов, переданных функции. Этот массив определен только во время выполнения функции. Свойство
arguments.length
позволяет определить количество элементов в массиве.