Когда число аргументов в вызове функции меньше числа объявленных параметров, недостающие аргументы получают значение
undefined
. Часто бывает удобным писать функции так, чтобы некоторые аргументы были необязательными и могли опускаться при вызове функции. В этом случае желательно предусмотреть возможность присваивания достаточно разумных значений по умолчанию параметрам, которые могут быть опущены. Например:
// Добавить в массив а перечислимые имена
свойств объекта о и вернуть его.
// Если аргумент а не не был передан, создать и вернуть новый массив,
function getPropertyNames(o, /* необязательный */ а) {
if (а === undefined) а = []; // Если массив не определен, создать новый
for(var property in о) a.push(property);
return а;
}
// Эта функция может вызываться с 1 или 2 аргументами:
var а = getPropertyNames(o); // Получить свойства объекта о в новом массиве
getPropertyNames(p,а); // добавить свойства объекта р в этот массив
Вместо инструкции if в первой строке этой функции можно использовать оператор || следующим образом:
а = а || [];
В разделе 4.10.2 говорилось, что оператор || возвращает первый аргумент, если он имеет истинное значение, и в противном случае возвращает второй аргумент. В данном примере, если во втором аргументе будет передан какой-либо объект, функция будет использовать его. Но если второй аргумент отсутствует (или в нем будет передано значение
null
), будет использоваться вновь созданный массив.
Обратите внимание, что при объявлении функций необязательные аргументы должны завершать список аргументов, чтобы их можно было опустить. Программист, который будет писать обращение к вашей функции, не сможет передать второй аргумент и при этом опустить первый: он будет вынужден явно передать в первом аргументе значение undefined. Обратите также внимание на комментарий /* необязательный */ в определении функции, который подчеркивает тот факт, что параметр является необязательным.
8.3.2. Списки аргументов переменной длины: объект Arguments
Если число аргументов в вызове функции превышает число имен параметров, функция лишается возможности напрямую обращаться к неименованным значениям. Решение этой проблемы предоставляет объект
Arguments
. В теле функции идентификатор
arguments
ссылается на объект
Arguments
, присутствующий в вызове. Объект
Arguments
– это объект, подобный массиву (раздел 7.11), позволяющий извлекать переданные функции значения по их номерам, а не по именам.
Предположим, что была определена функция f, которая требует
один аргумент, х. Если вызвать эту функцию с двумя аргументами, то первый будет доступен внутри функции по имени параметра х или как
arguments[0].
Второй аргумент будет доступен только как
arguments[1].
Кроме того, подобно настоящим массивам,
arguments
имеет свойство
length
, определяющее количество содержащихся элементов. То есть в теле функции f, вызываемой с двумя аргументами, arguments,
length
имеет значение 2.
Объект
Arguments
может использоваться с самыми разными целями. Следующий пример показывает, как с его помощью проверить, была ли функция вызвана с правильным числом аргументов, - ведь JavaScript этого за вас не сделает:
function f(x, у, z)
{
// Сначала проверяется, правильное ли количество аргументов передано
if (arguments.length != 3) {
throw new Error("функция f вызвана c ” + arguments.length +
"аргументами, а требуется 3.");
}
// А теперь сам код функции...
}
Обратите внимание, что зачастую нет необходимости проверять количество аргументов, как в данном примере. Поведение по умолчанию интерпретатора JavaScript отлично подходит для большинства случаев: отсутствующие аргументы замещаются значением
undefined
, а лишние аргументы просто игнорируются.
Объект
Arguments
иллюстрирует важную возможность JavaScript-функций: они могут быть написаны таким образом, чтобы работать с любым количеством аргументов. Следующая функция принимает любое число аргументов и возвращает значение самого большого из них (аналогично ведет себя встроенная функция Math.max):
function max(/*...*/)
{
var m = Number.NEGATIVE.INFINITY;
// Цикл по всем аргументам, поиск и сохранение наибольшего из них
for(var і = 0; і < arguments.length; i++)
if (arguments[i] > max) max = arguments[i];
// Вернуть наибольшее значение return max;
}
var largest = max(1, 10, 100, 2, 3, 1000, 4, 5, 10000, 6); // => 10000