- JavaScript Параметры функции
- Параметры и аргументы функции
- Правила параметра
- Параметры по умолчанию
- Пример
- Объект аргументов
- Пример
- Пример
- Аргументы передаются по значению
- Объекты передаются по ссылке
- Функции
- JavaScript Функции
- Объявление и вызов функции
- Объект arguments
- Интерактивный пример
- Синтаксис
- Описание
- Использование typeof с объектом arguments
- Использование оператора расширения для объекта arguments
- Свойства
- Примеры
- Создание функции, соединяющей несколько строк
- Функция, создающая HTML списки
- Остаточные, деструктурированные и параметры по умолчанию
- Спецификации
- Поддержка браузерами
- Смотрите также
- Found a content problem with this page?
- MDN
- Support
- Our communities
- Developers
JavaScript Параметры функции
JavaScript function не выполняет никакой проверки значений параметров (аргументов).
Параметры и аргументы функции
Ранее в этом руководстве вы узнали, что функции могут иметь параметры:
Параметры функции — это имена, перечисленные в определении функции.
Аргументы функции — это реальные значения, переданные (и полученные) функцией.
Правила параметра
В определениях функций JavaScript не указываются типы данных для параметров.
Функции JavaScript не выполняют проверку типов переданных аргументов.
Функции JavaScript не проверяют количество полученных аргументов.
Параметры по умолчанию
Если функция вызывается с отсутствующими аргументами (меньше объявленных), для отсутствующих значений устанавливается значение undefined .
Иногда это приемлемо, но иногда лучше присвоить параметру значение по умолчанию:
Пример
ECMAScript 2015 допускает значения параметров по умолчанию в объявлении функции:
Объект аргументов
Функции JavaScript имеют встроенный объект, называемый объектом аргументов.
Объект аргумента содержит массив аргументов, используемых при вызове (вызове) функции.
Таким образом, вы можете просто использовать функцию для поиска (например) наивысшего значения в списке чисел:
Пример
x = findMax(1, 123, 500, 115, 44, 88);
function findMax() var i;
var max = -Infinity;
for (i = 0; i < arguments.length; i++) if (arguments[i] > max) max = arguments[i];
>
>
return max;
>
Или создайте функцию для суммирования всех входных значений:
Пример
x = sumAll(1, 123, 500, 115, 44, 88);
function sumAll() var i;
var sum = 0;
for (i = 0; i < arguments.length; i++) sum += arguments[i];
>
return sum;
>
Если функция вызывается со слишком большим количеством аргументов (больше, чем объявлено), эти аргументы могут быть получены с помощью объекта arguments.
Аргументы передаются по значению
Параметры в вызове функции являются аргументами функции.
Аргументы JavaScript передаются по значению: функция узнает только значения, но не расположение аргументов.
Если функция изменяет значение аргумента, она не меняет исходное значение параметра.
Изменения аргументов не видны (не отражаются) вне функции.
Объекты передаются по ссылке
В JavaScript ссылки на объекты являются значениями.
Из-за этого объекты будут вести себя так, как будто они переданы по ссылке:
Если функция изменяет свойство объекта, она изменяет исходное значение.
Изменения свойств объекта видны (отражаются) вне функции.
Функции
Осваивайте профессию, начните зарабатывать, а платите через год!
Курсы Python Акция! Бесплатно!
Станьте хакером на Python за 3 дня
Веб-вёрстка. CSS, HTML и JavaScript
Станьте веб-разработчиком с нуля
Функции помогают снизить повторяемость кода за счет превращения часто встречающихся участков кода в независимые блоки, которые определяются один раз и могут вызываться многократно. В этой главе описаны основы их применения и соответствующие механизмы.
JavaScript Функции
Функция (function) – это самостоятельный фрагмент кода, решающий определенную задачу. Каждой функции присваивается уникальное имя, по которому ее можно идентифицировать и «вызвать» в нужный момент.
Функции в языке JavaScript являются объектами, и следовательно ими можно манипулировать как объектами. Например, функции могут присваиваться переменным, элементам массива, свойствам объектов, передавать в качестве аргумента функциям и возвращать в качестве значения из функций.
В JavaScript есть встроенные функции, которые можно использовать в программах, но код которых нельзя редактировать или посмотреть. Примеры встроенных функций вы уже видели – это alert() , prompt() , confirm() и document.write() . Кроме использования встроенных функций, вы можете создать свои собственные, так называемые пользовательские функции.
Объявление и вызов функции
Функция (как и всякий объект) должна быть объявлена (определена) перед её использованием.
- Идентификатор, определяющий имя функции. Чаще всего в качестве имен функций выбираются глаголы или фразы, начинающиеся с глаголов. По общепринятому соглашению имена функций начинаются со строчной буквы.
- Пара круглых скобок () , которые могут включать имена параметров, разделенных запятыми ( параметр1, параметр2, . ). Эти имена параметров в теле функции могут использоваться как локальные переменные.
- Пара фигурных скобок <> с инструкциями JavaScript внутри. Эти инструкции составляют тело функции: они выполняются при каждом вызове функции.
Синтаксис функции JavaScript:
function идентификатор(параметры)
Программный код, расположенный в теле функции, выполняется не в момент объявления функции, а в момент её вызова. Будучи один раз определенной, функция может сколько угодно раз вызываться с помощью оператора () (вызов функции):
Объект arguments
Объект arguments — это подобный массиву объект, который содержит аргументы, переданные в функцию.
Примечание: Если вы пишете ES6-совместимый код, то лучше использовать остаточные параметры.
Примечание: «Подобный массиву» означает, что arguments имеет свойство length , а элементы индексируются начиная с нуля. Но при этом он не может обращаться к встроенным методам Array , таким как forEach() или map() . Подробнее об этом в §Описании.
Интерактивный пример
Синтаксис
Описание
Объект arguments — это локальная переменная, доступная внутри любой (нестрелочной) функции. Объект arguments позволяет ссылаться на аргументы функции внутри неё. Он состоит из переданных в функцию аргументов, индексация начинается с 0. Например, если в функцию было передано 3 аргумента, обратиться к ним можно следующим образом:
Аргументам может быть присвоено значение:
Объект arguments не является Array . Он похож на массив, но не обладает ни одним из его свойств, кроме length . Например, у него нет метода pop . Однако, он может быть преобразован в обычный массив:
var args = Array.prototype.slice.call(arguments); var args = [].slice.call(arguments); // ES2015 const args = Array.from(arguments); const args = [. arguments];
Предупреждение: Использование slice на объекте arguments не позволяет сделать оптимизации в некоторых JavaScript движках (например, V8 — подробнее). Если они важны, можно попробовать вместо этого создать новый массив с аналогичной длиной и заполнить его элементами объекта arguments. Альтернативный вариант — использовать конструктор Array как функцию:
var args = (arguments.length === 1 ? [arguments[0]] : Array.apply(null, arguments));
Объект arguments можно использовать при вызове функции с бо́льшим количеством аргументов, чем было предусмотрено в её объявлении. Такой способ удобен для функций, в которые допустимо передавать переменное количество аргументов. Можно воспользоваться arguments.length , чтобы определить количество переданных в функцию аргументов, а затем обработать каждый из них с помощью объекта arguments . Чтобы определить количество параметров функции, описанных в её сигнатуре (en-US) , можно использовать свойство Function.length .
Использование typeof с объектом arguments
Применение оператора typeof к arguments вернёт ‘object’.
console.log(typeof arguments); // 'object'
Определение типов аргументов может быть выполнено применением оператора typeof и индексацией.
// выведет тип первого аргумента console.log(typeof arguments[0]);
Использование оператора расширения для объекта arguments
Как и с обычными массива-подобными объектами, для преобразования объекта arguments в обычный массив можно использовать метод Array.from() или оператор расширения:
var args = Array.from(arguments); var args = [. arguments];
Свойства
Ссылка на функцию, которая выполняется в текущий момент.
Ссылка на функцию, которая вызвала функцию, выполняющуюся в текущий момент.
Количество переданных в функцию аргументов.
Возвращает новый объект Array Iterator , содержащий значения для каждого индекса в массиве.
Примеры
Создание функции, соединяющей несколько строк
Данный пример описывает функцию, которая соединяет несколько строк. Для этой функции объявлен только один аргумент, определяющий символ-разделитель соединяемых элементов. Функция определена следующим образом:
function myConcat(separator) var args = Array.prototype.slice.call(arguments, 1); return args.join(separator); >
Вы можете передать любое количество аргументов в эту функцию. Она создаёт строку, используя каждый аргумент:
// возвращает "red, orange, blue" myConcat(", ", "red", "orange", "blue"); // получает "elephant; giraffe; lion; cheetah" myConcat("; ", "elephant", "giraffe", "lion", "cheetah"); // выводит "sage. basil. oregano. pepper. parsley" myConcat(". ", "sage", "basil", "oregano", "pepper", "parsley");
Функция, создающая HTML списки
В данном примере приведена функция, которая создаёт строку с HTML-разметкой для списка. Единственный её аргумент — строка, определяющая вид списка: если его значение равно «u», формируется неупорядоченный (маркированный) список, а если «o» — то упорядоченный (нумерованный):
Вы можете использовать любое количество аргументов, а функция добавит каждый элемент в список заданного первым аргументом типа. Например:
Остаточные, деструктурированные и параметры по умолчанию
function foo(. args) return arguments; > foo(1, 2, 3); //
Тем не менее, в нестрогих функциях соответствие между их аргументами и объектом arguments существует только в том случае, если функция не содержит никаких остаточных параметров, параметров по умолчанию или деструктурированных параметров. Например, в функции, приведённой ниже, используется параметр по умолчанию, и в данном случае возвращаемый результат будет равен 10, а не 100:
function bar(a=1) arguments[0] = 100; return a; > bar(10); // 10
function zoo(a) arguments[0] = 100; return a; > zoo(10); // 100
На самом деле, если остаточные параметры, параметры по умолчанию или деструктурированные параметры не используются, формальные аргументы будут ссылаться на последние значения объекта arguments , при считывании значений формальных аргументов будут считаны последние данные из arguments , а при изменении значений формальных аргументов будет обновлён и объект arguments . Пример приведён в коде ниже:
function func(a, b) arguments[0] = 90; arguments[1] = 99; console.log(a + " " + b); > func(1, 2); //90, 99
function func(a, b) a = 9; b = 99; console.log(arguments[0] + " " + arguments[1]); > func(3, 4); //9, 99
Но в случае, когда применяются остаточные параметры, параметры по умолчанию или деструктурированные параметры, будет обработано нормальное поведение, как в случае параметров по умолчанию:
function func(a, b, c=9) arguments[0] = 99; arguments[1] = 98; console.log(a + " " + b); > func(3, 4); //3, 4
Спецификации
Поддержка браузерами
BCD tables only load in the browser
Смотрите также
Found a content problem with this page?
This page was last modified on 17 июл. 2023 г. by MDN contributors.
Your blueprint for a better internet.
MDN
Support
Our communities
Developers
Visit Mozilla Corporation’s not-for-profit parent, the Mozilla Foundation.
Portions of this content are ©1998– 2023 by individual mozilla.org contributors. Content available under a Creative Commons license.