Как вернуть несколько значений из функции javascript
Перейти к содержимому

Как вернуть несколько значений из функции javascript

  • автор:

Возврат нескольких значений из метода в JavaScript

В этом посте мы обсудим, как вернуть несколько значений из метода в JavaScript.

1. Вернуть массив

Идея состоит в том, чтобы упаковать возвращаемые значения внутри массива и вернуть этот массив из метода. В следующем примере кода показано, как это реализовать:

function getValues ( ) < return [ 1 , 2 ] ; var values = getValues ( ) ; var first = values [ 0 ] ; var second = values [ 1 ] ; console . log ( "First Value: " + first ) ; console . log ( "Second Value: " + second ) ; Первое значение: 1 Второе значение: 2

В следующем коде используется присваивание деструктуризации распаковывать значения из массивов в соответствующие переменные.

function getValues ( ) < return [ 1 , 2 ] ; const [ first , second ] = getValues ( ) ; console . log ( "First Value: " + first ) ; console . log ( "Second Value: " + second ) ; Первое значение: 1 Второе значение: 2

2. Вернуть объект

Другой подход состоит в том, чтобы упаковать возвращаемые значения внутри объекта с соответствующими метками и вернуть объект из метода. В следующем примере кода показано, как это реализовать:

function getValues ( ) < var values = getValues ( ) ; var first = values . x ; var second = values . y ; console . log ( "First Value: " + first ) ; console . log ( "Second Value: " + second ) ; Первое значение: 1 Второе значение: 2

Код можно упростить, используя присваивание деструктуризации:

function getValues ( ) < const < x , y >= getValues ( ) ;
console . log ( «First Value: » + x ) ;
console . log ( «Second Value: » + y ) ;
Первое значение: 1
Второе значение: 2

Это все о возврате нескольких значений из метода в JavaScript.

Оценить этот пост

Средний рейтинг 5 /5. Подсчет голосов: 22

Голосов пока нет! Будьте первым, кто оценит этот пост.

Сожалеем, что этот пост не оказался для вас полезным!

Расскажите, как мы можем улучшить этот пост?

Спасибо за чтение.

Пожалуйста, используйте наш онлайн-компилятор размещать код в комментариях, используя C, C++, Java, Python, JavaScript, C#, PHP и многие другие популярные языки программирования.

Как мы? Порекомендуйте нас своим друзьям и помогите нам расти. Удачного кодирования 🙂

Подписывайся
0 Комментарии
Встроенные отзывы
Просмотреть все комментарии
Загрузить больше комментариев
Просматривать
Подпишитесь на новые публикации

  • Все проблемы
  • Практика DSA
  • 100 самых популярных задач
  • 50 лучших классических задач
  • Лучшие алгоритмы
  • Компилятор С/С++
  • Компилятор Java
  • Компилятор Python
  • Компилятор JavaScript
  • компилятор PHP
  • Компилятор C#
  • Свяжитесь с нами
  • Политика конфиденциальности
  • условия обслуживания
  • Подпишитесь на новые публикации

Techie Delight © 2023 Все права защищены.

Этот веб-сайт использует файлы cookie. Используя этот сайт, вы соглашаетесь с использованием файлов cookie, нашей политикой, условиями авторского права и другими условиями. Читайте наши Политика конфиденциальности. Понятно

Можно ли в return вернуть два значения?

Так нет, у тебя вернется только a. Можешь создать объект или массив и возвращать его.

Ответ написан более трёх лет назад

Комментировать

Нравится 3 Комментировать

dimsog

Переносил код с PHP 4 на 7.4.

Потому что return это выход из функции. Вы всегда можете вернуть два значения, если будете возвращать массив.
Например вот так:

function ab() < let a = 0; let b = 1 return [a, b];

Можно возвращать и объект:

function ab() < let a = 0; let b = 1 return < a, b >;

Ответ написан более трёх лет назад

Возвращение нескольких значений в JavaScript

Visual representation of returning multiple values in JavaScript.

При разработке на JavaScript иногда возникает необходимость вернуть из функции сразу несколько значений. Возьмем простой пример:

function calculate()

В данном случае, кажется, что функция должна вернуть два значения: результат сложения и разности. Однако, на самом деле, это не так.

В JavaScript функция может вернуть только одно значение. Если вы попробуете использовать вышеприведенный код, то увидите, что функция calculate возвращает только значение diff , игнорируя значение sum . Это происходит из-за того, что оператор , в языке JavaScript возвращает последнее значение.

Чтобы вернуть из функции несколько значений, необходимо использовать другие подходы. В JavaScript для этого есть несколько способов.

Возвращение значений в виде массива

Один из наиболее простых и удобных способов — вернуть значения в виде массива.

function calculate()

Теперь при вызове функции calculate вернется массив, первым элементом которого будет sum , а вторым — diff .

Возвращение значений в виде объекта

Если необходимо вернуть из функции несколько значений, которые имеют разный смысл, то удобно использовать объекты.

function calculate() < var sum = 1 + 2; var diff = 2 - 1; return < sum: sum, difference: diff >; >

При вызове функции calculate будет возвращен объект, полями которого будут sum и difference . Этот способ полезен тем, что позволяет явно обозначить, что означает каждое из возвращаемых значений.

Выбор использования массива или объекта зависит от конкретной ситуации, и в большинстве случаев любой из этих подходов позволит решить задачу.

Возвращаемые значения функций

Для нас в этом курсе имеется ещё один важный момент. Посмотрим внимательнее на возвращаемое значение функций. Некоторые функции не возвращают существенное значение после завершения, но некоторые возвращают, и важно понимать что это за значение и как использовать его в своём коде и как сделать так чтобы ваши собственные функции возвращали полезные значения. Мы объясним всё это ниже.

Необходимые навыки: Базовая компьютерная грамотность, знание основ HTML и CSS, JavaScript first steps, Functions — reusable blocks of code.
Цели: Понять что такое возвращаемое значение функции и как его использовать.

Что из себя представляют возвращаемые значения?

Возвращаемые значения - это на самом деле просто значения, которые функция возвращает после своего завершения. Вы уже неоднократно встречали возвращаемые значения, хотя, возможно, и не осознавали этого. Напишем небольшой код:

var myText = "I am a string"; var newString = myText.replace("string", "sausage"); console.log(newString); // функция replace() принимает строку, // заменяет одну подстроку другой и возвращает // новую строку со сделанными заменами 

Мы уже видели этот блок кода в нашей первой статье про функции. Мы вызываем функцию replace() на строке myText и передаём ей 2 параметра — заменяемую подстроку и подстроку, которой будем заменять. Когда функция завершит выполнение, она вернёт значение, которым является новая строка со сделанными в ней заменами. В коде выше мы сохраняем это возвращаемое значение как значение переменной newString .

Если вы посмотрите на функцию replace() на MDN reference page, вы увидите секцию под названием Return value. Очень важно знать и понимать какие значения возвращаются функциями, так что мы пытаемся включать эту информацию везде, где это возможно.

Некоторые функции не возвращают значения( на наших reference pages, возвращаемое значение обозначено как void или undefined в таких случаях). Например, в функции displayMessage() которую мы сделали в прошлой статье, в результате выполнения функции не возвращается никакого значения. Функция всего лишь отображает что-то где-то на экране.

В основном, возвращаемое значение используется там, где функция является чем-то вроде вспомогательного звена при вычислениях. Вы хотите получить результат, который включает в себя некоторые значения. Эти значения вычисляются функцией, которая возвращает результат так, что он может быть использован в следующих стадиях вычисления.

Использование возвращаемых значений в ваших собственных функциях

Чтобы вернуть значение своей функции, вы должны использовать ключевое слово return. Мы видели это в действии недавно - в нашем примере random-canvas-circles.html. Наша функция draw() отрисовывает где-то на экране 100 случайных кружков.

function draw()  ctx.clearRect(0, 0, WIDTH, HEIGHT); for (var i = 0; i  100; i++)  ctx.beginPath(); ctx.fillStyle = "rgba(255,0,0,0.5)"; ctx.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI); ctx.fill(); > > 

Внутри каждой итерации есть 3 вызова функции random() . Это сделано чтобы сгенерировать случайное значение для текущей координаты x, y и для радиуса. Функция random() принимает 1 параметр (целое число) и возвращает случайное число в диапазоне от 0 до этого числа. Выглядит это вот так:

function random(number)  return Math.floor(Math.random() * number); > 

Тоже самое может быть написано вот так:

function random(number)  var result = Math.floor(Math.random() * number); return result; > 

Но первую версию написать быстрее и она более компактна.

Мы возвращаем результат вычисления Math.floor(Math.random()*number) каждый раз когда функция вызывается. Это возвращаемое значение появляется в момент вызова функции и код продолжается. Так, например, если мы выполним следующую строчку:

.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI); 

и 3 вызова random() вернут значения 500, 200 и 35, соответственно, строчка будет выполнена как если бы она была такой:

.arc(500, 200, 35, 0, 2 * Math.PI); 

Сначала выполняются вызовы функции random() , на место которых подставляются возвращаемые ей значения, а затем выполнятся сама строка.

Активное обучение: наша собственная, возвращающая значение функция

Теперь напишем нашу собственную возвращающую значение функцию.

function squared(num)  return num * num; > function cubed(num)  return num * num * num; > function factorial(num)  var x = num; while (x > 1)  num *= x - 1; x--; > return num; > 
.onchange = function ()  var num = input.value; if (isNaN(num))  para.textContent = "You need to enter a number!"; > else  para.textContent = num + " squared is " + squared(num) + ". " + num + " cubed is " + cubed(num) + ". " + num + " factorial is " + factorial(num) + "."; > >; 

Примечание: Если у вас проблемы с работой данного примера, не стесняйтесь сверить ваш код с работающей версией finished version on GitHub (или смотрите живой пример), или спросите нас.

К этому моменту мы хотели бы чтобы вы написали парочку собственных функций и добавили их в библиотеку. Как на счёт квадратного или кубического корня числа или длины окружности круга с длиной радиуса равной числу num ?

Это упражнение привнесло парочку важных понятий в изучении того, как использовать ключевое слово return . В дополнение:

  • Приведите другой пример написание обработчика ошибок. Это довольно хорошая идея проверять что важные параметры предоставлены в правильном типе и если они опциональны то предусматривать для них значения по умолчанию. В таком случая ваша программа с меньшей вероятность подвержена ошибкам.
  • Поразмышляйте о идее создания библиотеки функций. Чем дальше вы будите расти в профессиональном плане, тем больше будете сталкиваться с однотипными вещами. Это хорошая идея начать собирать свою собственную библиотеку функций, которые вы часто используют — в таком случае вы сможете просто скопировать их в ваш новый код или просто добавить их в любую HTML страничку, где это требуется.

Заключение

Функции очень полезны и несмотря на то, что об их синтаксисе и функциональности можно говорить долго, у нас есть довольно понятные статьи для дальнейшего обучения.

Если в статье есть что-то что вы не поняли, не стесняйтесь перечитать статью ещё раз или свяжитесь с нами для получения помощи.

Смотрите также

  • Функции более подробно — подробное руководство, охватывающее более продвинутую информацию, связанную с функциями.
  • Колбэк-функции в JavaScript — распространённый паттерн JavaScript для передачи функции в другую функцию как аргумент, который затем вызывается внутри первой функции.
  • Назад
  • Обзор: Building blocks
  • Далее

In this module

  • Making decisions in your code — conditionals
  • Looping code
  • Functions — reusable blocks of code
  • Build your own function
  • Function return values
  • Introduction to events
  • Image gallery

Found a content problem with this page?

  • Edit the page on GitHub.
  • Report the content issue.
  • View the source on GitHub.

This page was last modified on 3 авг. 2023 г. by MDN contributors.

Your blueprint for a better internet.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *