98 lines
4.1 KiB
Markdown
98 lines
4.1 KiB
Markdown
|
---
|
|||
|
id: 56533eb9ac21ba0edf2244bd
|
|||
|
title: Passing Values to Functions with Arguments
|
|||
|
challengeType: 1
|
|||
|
videoUrl: ''
|
|||
|
localeTitle: Передача значений в функции с аргументами
|
|||
|
---
|
|||
|
|
|||
|
## Description
|
|||
|
<section id="description"> <dfn>Параметры</dfn> - это переменные, которые действуют как заполнители для значений, которые должны быть введены в функцию при ее вызове. Когда функция определена, она обычно определяется вместе с одним или несколькими параметрами. Фактические значения, которые вводятся (или <dfn>«переданы»</dfn> ) в функцию при ее вызове, называются <dfn>аргументами</dfn> . Вот функция с двумя параметрами <code>param1</code> и <code>param2</code> : <blockquote> function testFun (param1, param2) { <br> console.log (param1, param2); <br> } </blockquote> Затем мы можем вызвать <code>testFun</code> : <code>testFun("Hello", "World");</code> Мы передали два аргумента: <code>"Hello"</code> и <code>"World"</code> . Внутри функции <code>param1</code> будет равен «Hello», а <code>param2</code> будет равен «World». Обратите внимание, что вы можете снова вызвать <code>testFun</code> с разными аргументами, и параметры будут принимать значение новых аргументов. </section>
|
|||
|
|
|||
|
## Instructions
|
|||
|
<section id="instructions"><ol><li> Создайте функцию <code>functionWithArgs</code> которая принимает два аргумента и выводит их сумму в консоль dev. </li><li> Вызовите функцию с двумя числами в качестве аргументов. </li></ol></section>
|
|||
|
|
|||
|
## Tests
|
|||
|
<section id='tests'>
|
|||
|
|
|||
|
```yml
|
|||
|
tests:
|
|||
|
- text: <code>functionWithArgs</code> должна быть функцией
|
|||
|
testString: 'assert(typeof functionWithArgs === "function", "<code>functionWithArgs</code> should be a function");'
|
|||
|
- text: '<code>functionWithArgs(1,2)</code> должен выводить <code>3</code>'
|
|||
|
testString: 'if(typeof functionWithArgs === "function") { capture(); functionWithArgs(1,2); uncapture(); } assert(logOutput == 3, "<code>functionWithArgs(1,2)</code> should output <code>3</code>");'
|
|||
|
- text: '<code>functionWithArgs(7,9)</code> должен выводить <code>16</code>'
|
|||
|
testString: 'if(typeof functionWithArgs === "function") { capture(); functionWithArgs(7,9); uncapture(); } assert(logOutput == 16, "<code>functionWithArgs(7,9)</code> should output <code>16</code>");'
|
|||
|
- text: Вызовите <code>functionWithArgs</code> с двумя номерами после ее определения.
|
|||
|
testString: 'assert(/^\s*functionWithArgs\s*\(\s*\d+\s*,\s*\d+\s*\)\s*;/m.test(code), "Call <code>functionWithArgs</code> with two numbers after you define it.");'
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
</section>
|
|||
|
|
|||
|
## Challenge Seed
|
|||
|
<section id='challengeSeed'>
|
|||
|
|
|||
|
<div id='js-seed'>
|
|||
|
|
|||
|
```js
|
|||
|
// Example
|
|||
|
function ourFunctionWithArgs(a, b) {
|
|||
|
console.log(a - b);
|
|||
|
}
|
|||
|
ourFunctionWithArgs(10, 5); // Outputs 5
|
|||
|
|
|||
|
// Only change code below this line.
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
</div>
|
|||
|
|
|||
|
### Before Test
|
|||
|
<div id='js-setup'>
|
|||
|
|
|||
|
```js
|
|||
|
var logOutput = "";
|
|||
|
var originalConsole = console
|
|||
|
function capture() {
|
|||
|
var nativeLog = console.log;
|
|||
|
console.log = function (message) {
|
|||
|
if(message) logOutput = JSON.stringify(message).trim();
|
|||
|
if(nativeLog.apply) {
|
|||
|
nativeLog.apply(originalConsole, arguments);
|
|||
|
} else {
|
|||
|
var nativeMsg = Array.prototype.slice.apply(arguments).join(' ');
|
|||
|
nativeLog(nativeMsg);
|
|||
|
}
|
|||
|
};
|
|||
|
}
|
|||
|
|
|||
|
function uncapture() {
|
|||
|
console.log = originalConsole.log;
|
|||
|
}
|
|||
|
|
|||
|
capture();
|
|||
|
|
|||
|
```
|
|||
|
|
|||
|
</div>
|
|||
|
|
|||
|
### After Test
|
|||
|
<div id='js-teardown'>
|
|||
|
|
|||
|
```js
|
|||
|
console.info('after the test');
|
|||
|
```
|
|||
|
|
|||
|
</div>
|
|||
|
|
|||
|
</section>
|
|||
|
|
|||
|
## Solution
|
|||
|
<section id='solution'>
|
|||
|
|
|||
|
```js
|
|||
|
// solution required
|
|||
|
```
|
|||
|
</section>
|