* chore(learn): audit basic algorithm scripting * chore(learn): audit basic data structures * chore(learn): audit basic javascript * chore(learn): audit debugging * chore(learn): audit es6 * chore(learn): audit functional programming * chore(learn): audit intermidate algorithms * chore(learn): audit js projects * chore(learn): audit object oriented programming * chore(learn): audit regex * fix(learn): remove stray . * fix(learn): string to code * fix(learn): missed some * fix(learn): clarify strings Based on Randy's feedback, clarifies string instances where quotes were removed in favour of back ticks. * fix: apply suggestions - thanks Randy! :) Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> * fix: non-suggestion comments * chore(learn): remove comments from codes Removes the comments from the description and instruction code blocks to ensure that all relevant information is translatable. * fix: Apply suggestions from code review Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * fix: revert crowdin fix * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-algorithm-scripting/mutations.md Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> * fix: Apply suggestions from code review Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/es6/use-destructuring-assignment-to-assign-variables-from-arrays.md Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * fix: Apply suggestions from code review Co-authored-by: Oliver Eyton-Williams <ojeytonwilliams@gmail.com> Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * chore: change voice * fix: Christopher Nolan * fix: expressions would evaluate * fix: will -> would * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/object-oriented-programming/add-methods-after-inheritance.md Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> * fix: to work to push * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/basic-javascript/iterate-with-javascript-for-loops.md Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> * Update curriculum/challenges/english/02-javascript-algorithms-and-data-structures/object-oriented-programming/add-methods-after-inheritance.md Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> Co-authored-by: Randell Dawson <5313213+RandellDawson@users.noreply.github.com> Co-authored-by: Shaun Hamilton <51722130+ShaunSHamilton@users.noreply.github.com> Co-authored-by: Oliver Eyton-Williams <ojeytonwilliams@gmail.com>
		
			
				
	
	
		
			95 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
---
 | 
						|
id: 587d7b8a367417b2b2512b4d
 | 
						|
title: Use Destructuring Assignment to Pass an Object as a Function's Parameters
 | 
						|
challengeType: 1
 | 
						|
forumTopicId: 301217
 | 
						|
dashedName: use-destructuring-assignment-to-pass-an-object-as-a-functions-parameters
 | 
						|
---
 | 
						|
 | 
						|
# --description--
 | 
						|
 | 
						|
In some cases, you can destructure the object in a function argument itself.
 | 
						|
 | 
						|
Consider the code below:
 | 
						|
 | 
						|
```js
 | 
						|
const profileUpdate = (profileData) => {
 | 
						|
  const { name, age, nationality, location } = profileData;
 | 
						|
 | 
						|
}
 | 
						|
```
 | 
						|
 | 
						|
This effectively destructures the object sent into the function. This can also be done in-place:
 | 
						|
 | 
						|
```js
 | 
						|
const profileUpdate = ({ name, age, nationality, location }) => {
 | 
						|
 | 
						|
}
 | 
						|
```
 | 
						|
 | 
						|
When `profileData` is passed to the above function, the values are destructured from the function parameter for use within the function.
 | 
						|
 | 
						|
# --instructions--
 | 
						|
 | 
						|
Use destructuring assignment within the argument to the function `half` to send only `max` and `min` inside the function.
 | 
						|
 | 
						|
# --hints--
 | 
						|
 | 
						|
`stats` should be an `object`.
 | 
						|
 | 
						|
```js
 | 
						|
assert(typeof stats === 'object');
 | 
						|
```
 | 
						|
 | 
						|
`half(stats)` should be `28.015`
 | 
						|
 | 
						|
```js
 | 
						|
assert(half(stats) === 28.015);
 | 
						|
```
 | 
						|
 | 
						|
Destructuring should be used.
 | 
						|
 | 
						|
```js
 | 
						|
assert(__helpers.removeWhiteSpace(code).match(/half=\({\w+,\w+}\)/));
 | 
						|
```
 | 
						|
 | 
						|
Destructured parameter should be used.
 | 
						|
 | 
						|
```js
 | 
						|
assert(!code.match(/stats\.max|stats\.min/));
 | 
						|
```
 | 
						|
 | 
						|
# --seed--
 | 
						|
 | 
						|
## --seed-contents--
 | 
						|
 | 
						|
```js
 | 
						|
const stats = {
 | 
						|
  max: 56.78,
 | 
						|
  standard_deviation: 4.34,
 | 
						|
  median: 34.54,
 | 
						|
  mode: 23.87,
 | 
						|
  min: -0.75,
 | 
						|
  average: 35.85
 | 
						|
};
 | 
						|
 | 
						|
// Only change code below this line
 | 
						|
const half = (stats) => (stats.max + stats.min) / 2.0; 
 | 
						|
// Only change code above this line
 | 
						|
```
 | 
						|
 | 
						|
# --solutions--
 | 
						|
 | 
						|
```js
 | 
						|
const stats = {
 | 
						|
  max: 56.78,
 | 
						|
  standard_deviation: 4.34,
 | 
						|
  median: 34.54,
 | 
						|
  mode: 23.87,
 | 
						|
  min: -0.75,
 | 
						|
  average: 35.85
 | 
						|
};
 | 
						|
 | 
						|
const half = ( {max, min} ) => (max + min) / 2.0;
 | 
						|
```
 |