Книга: JavaScript. Подробное руководство, 6-е издание

8.3.1. Необязательные аргументы

8.3.1. Необязательные аргументы

Когда число аргументов в вызове функции меньше числа объявленных параметров, недостающие аргументы получают значение 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. Обратите также внимание на комментарий /* необязательный */ в определении функции, который подчеркивает тот факт, что параметр является необязательным.

Оглавление книги


Генерация: 0.051. Запросов К БД/Cache: 0 / 3
поделиться
Вверх Вниз