* 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>
		
			
				
	
	
		
			89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			89 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 587d7da9367417b2b2512b67
 | |
| title: Add Elements to the End of an Array Using concat Instead of push
 | |
| challengeType: 1
 | |
| forumTopicId: 301226
 | |
| dashedName: add-elements-to-the-end-of-an-array-using-concat-instead-of-push
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| Functional programming is all about creating and using non-mutating functions.
 | |
| 
 | |
| The last challenge introduced the `concat` method as a way to combine arrays into a new one without mutating the original arrays. Compare `concat` to the `push` method. `push` adds an item to the end of the same array it is called on, which mutates that array. Here's an example:
 | |
| 
 | |
| ```js
 | |
| var arr = [1, 2, 3];
 | |
| arr.push([4, 5, 6]);
 | |
| ```
 | |
| 
 | |
| `arr` would have a modified value of `[1, 2, 3, [4, 5, 6]]`, which is not the functional programming way.
 | |
| 
 | |
| `concat` offers a way to add new items to the end of an array without any mutating side effects.
 | |
| 
 | |
| # --instructions--
 | |
| 
 | |
| Change the `nonMutatingPush` function so it uses `concat` to add `newItem` to the end of `original` instead of `push`. The function should return an array.
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| Your code should use the `concat` method.
 | |
| 
 | |
| ```js
 | |
| assert(code.match(/\.concat/g));
 | |
| ```
 | |
| 
 | |
| Your code should not use the `push` method.
 | |
| 
 | |
| ```js
 | |
| assert(!code.match(/\.?[\s\S]*?push/g));
 | |
| ```
 | |
| 
 | |
| The `first` array should not change.
 | |
| 
 | |
| ```js
 | |
| assert(JSON.stringify(first) === JSON.stringify([1, 2, 3]));
 | |
| ```
 | |
| 
 | |
| The `second` array should not change.
 | |
| 
 | |
| ```js
 | |
| assert(JSON.stringify(second) === JSON.stringify([4, 5]));
 | |
| ```
 | |
| 
 | |
| `nonMutatingPush([1, 2, 3], [4, 5])` should return `[1, 2, 3, 4, 5]`.
 | |
| 
 | |
| ```js
 | |
| assert(
 | |
|   JSON.stringify(nonMutatingPush([1, 2, 3], [4, 5])) ===
 | |
|     JSON.stringify([1, 2, 3, 4, 5])
 | |
| );
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```js
 | |
| function nonMutatingPush(original, newItem) {
 | |
|   // Only change code below this line
 | |
|   return original.push(newItem);
 | |
| 
 | |
|   // Only change code above this line
 | |
| }
 | |
| var first = [1, 2, 3];
 | |
| var second = [4, 5];
 | |
| nonMutatingPush(first, second);
 | |
| ```
 | |
| 
 | |
| # --solutions--
 | |
| 
 | |
| ```js
 | |
| function nonMutatingPush(original, newItem) {
 | |
|   return original.concat(newItem);
 | |
| }
 | |
| var first = [1, 2, 3];
 | |
| var second = [4, 5];
 | |
| nonMutatingPush(first, second);
 | |
| ```
 |