* fix: convert js algorithms and data structures * fix: revert some blocks back to blockquote * fix: reverted comparison code block to blockquotes * fix: change js to json Co-Authored-By: Oliver Eyton-Williams <ojeytonwilliams@gmail.com> * fix: convert various section to triple backticks * fix: Make the formatting consistent for comparisons
		
			
				
	
	
		
			86 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			86 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 56533eb9ac21ba0edf2244ba
 | |
| title: Understand String Immutability
 | |
| challengeType: 1
 | |
| videoUrl: 'https://scrimba.com/c/cWPVaUR'
 | |
| ---
 | |
| 
 | |
| ## Description
 | |
| <section id='description'>
 | |
| In JavaScript, <code>String</code> values are <dfn>immutable</dfn>, which means that they cannot be altered once created.
 | |
| For example, the following code:
 | |
| 
 | |
| ```js
 | |
| var myStr = "Bob";
 | |
| myStr[0] = "J";
 | |
| ```
 | |
| 
 | |
| cannot change the value of <code>myStr</code> to "Job", because the contents of <code>myStr</code> cannot be altered. Note that this does <em>not</em> mean that <code>myStr</code> cannot be changed, just that the individual characters of a <dfn>string literal</dfn> cannot be changed. The only way to change <code>myStr</code> would be to assign it with a new string, like this:
 | |
| 
 | |
| ```js
 | |
| var myStr = "Bob";
 | |
| myStr = "Job";
 | |
| ```
 | |
| 
 | |
| </section>
 | |
| 
 | |
| ## Instructions
 | |
| <section id='instructions'>
 | |
| Correct the assignment to <code>myStr</code> so it contains the string value of <code>Hello World</code> using the approach shown in the example above.
 | |
| </section>
 | |
| 
 | |
| ## Tests
 | |
| <section id='tests'>
 | |
| 
 | |
| ```yml
 | |
| tests:
 | |
|   - text: <code>myStr</code> should have a value of <code>Hello World</code>
 | |
|     testString: assert(myStr === "Hello World", '<code>myStr</code> should have a value of <code>Hello World</code>');
 | |
|   - text: Do not change the code above the line
 | |
|     testString: assert(/myStr = "Jello World"/.test(code), 'Do not change the code above the line');
 | |
| 
 | |
| ```
 | |
| 
 | |
| </section>
 | |
| 
 | |
| ## Challenge Seed
 | |
| <section id='challengeSeed'>
 | |
| 
 | |
| <div id='js-seed'>
 | |
| 
 | |
| ```js
 | |
| // Setup
 | |
| var myStr = "Jello World";
 | |
| 
 | |
| // Only change code below this line
 | |
| 
 | |
| myStr[0] = "H"; // Fix Me
 | |
| 
 | |
| 
 | |
| ```
 | |
| 
 | |
| </div>
 | |
| 
 | |
| 
 | |
| ### After Test
 | |
| <div id='js-teardown'>
 | |
| 
 | |
| ```js
 | |
| (function(v){return "myStr = " + v;})(myStr);
 | |
| ```
 | |
| 
 | |
| </div>
 | |
| 
 | |
| </section>
 | |
| 
 | |
| ## Solution
 | |
| <section id='solution'>
 | |
| 
 | |
| 
 | |
| ```js
 | |
| var myStr = "Jello World";
 | |
| myStr = "Hello World";
 | |
| ```
 | |
| 
 | |
| </section>
 |