91 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
---
 | 
						|
id: 598f48a36c8c40764b4e52b3
 | 
						|
title: Prevent Object Mutation
 | 
						|
challengeType: 1
 | 
						|
---
 | 
						|
 | 
						|
## Description
 | 
						|
<section id='description'>
 | 
						|
As seen in the previous challenge, <code>const</code> declaration alone doesn't really protect your data from mutation. To ensure your data doesn't change, JavaScript provides a function <code>Object.freeze</code> to prevent data mutation.
 | 
						|
Once the object is frozen, you can no longer add, update, or delete properties from it. Any attempt at changing the object will be rejected without an error.
 | 
						|
<blockquote>let obj = {<br>  name:"FreeCodeCamp",<br>  review:"Awesome"<br>};<br>Object.freeze(obj);<br>obj.review = "bad"; // will be ignored. Mutation not allowed<br>obj.newProp = "Test"; // will be ignored. Mutation not allowed<br>console.log(obj); <br>// { name: "FreeCodeCamp", review:"Awesome"}</blockquote>
 | 
						|
</section>
 | 
						|
 | 
						|
## Instructions
 | 
						|
<section id='instructions'>
 | 
						|
In this challenge you are going to use <code>Object.freeze</code> to prevent mathematical constants from changing. You need to freeze the <code>MATH_CONSTANTS</code> object so that no one is able to alter the value of <code>PI</code>, add, or delete properties.
 | 
						|
</section>
 | 
						|
 | 
						|
## Tests
 | 
						|
<section id='tests'>
 | 
						|
 | 
						|
```yml
 | 
						|
tests:
 | 
						|
  - text: Do not replace <code>const</code> keyword.
 | 
						|
    testString: getUserInput => assert(getUserInput('index').match(/const/g), 'Do not replace <code>const</code> keyword.');
 | 
						|
  - text: <code>MATH_CONSTANTS</code> should be a constant variable (by using <code>const</code>).
 | 
						|
    testString: getUserInput => assert(getUserInput('index').match(/const\s+MATH_CONSTANTS/g), '<code>MATH_CONSTANTS</code> should be a constant variable (by using <code>const</code>).');
 | 
						|
  - text: Do not change original <code>MATH_CONSTANTS</code>.
 | 
						|
    testString: getUserInput => assert(getUserInput('index').match(/const\s+MATH_CONSTANTS\s+=\s+{\s+PI:\s+3.14\s+};/g), 'Do not change original <code>MATH_CONSTANTS</code>.');
 | 
						|
  - text: <code>PI</code> equals <code>3.14</code>.
 | 
						|
    testString: assert(PI === 3.14, '<code>PI</code> equals <code>3.14</code>.');
 | 
						|
 | 
						|
```
 | 
						|
 | 
						|
</section>
 | 
						|
 | 
						|
## Challenge Seed
 | 
						|
<section id='challengeSeed'>
 | 
						|
 | 
						|
<div id='js-seed'>
 | 
						|
 | 
						|
```js
 | 
						|
function freezeObj() {
 | 
						|
  'use strict';
 | 
						|
  const MATH_CONSTANTS = {
 | 
						|
    PI: 3.14
 | 
						|
  };
 | 
						|
  // change code below this line
 | 
						|
 | 
						|
 | 
						|
  // change code above this line
 | 
						|
  try {
 | 
						|
    MATH_CONSTANTS.PI = 99;
 | 
						|
  } catch(ex) {
 | 
						|
    console.log(ex);
 | 
						|
  }
 | 
						|
  return MATH_CONSTANTS.PI;
 | 
						|
}
 | 
						|
const PI = freezeObj();
 | 
						|
```
 | 
						|
 | 
						|
</div>
 | 
						|
 | 
						|
 | 
						|
 | 
						|
</section>
 | 
						|
 | 
						|
## Solution
 | 
						|
<section id='solution'>
 | 
						|
 | 
						|
```js
 | 
						|
function freezeObj() {
 | 
						|
  'use strict';
 | 
						|
  const MATH_CONSTANTS = {
 | 
						|
    PI: 3.14
 | 
						|
  };
 | 
						|
  // change code below this line
 | 
						|
  Object.freeze(MATH_CONSTANTS);
 | 
						|
 | 
						|
  // change code above this line
 | 
						|
  try {
 | 
						|
    MATH_CONSTANTS.PI = 99;
 | 
						|
  } catch(ex) {
 | 
						|
    console.log(ex);
 | 
						|
  }
 | 
						|
  return MATH_CONSTANTS.PI;
 | 
						|
}
 | 
						|
const PI = freezeObj();
 | 
						|
```
 | 
						|
</section>
 |