149 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			149 lines
		
	
	
		
			7.5 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|   | --- | ||
|  | title: Convert HTML Entities | ||
|  | --- | ||
|  |  | ||
|  | 
 | ||
|  |  Remember to use <a>**`Read-Search-Ask`**</a> if you get stuck. Try to pair program  and write your own code  | ||
|  | 
 | ||
|  | ###  Problem Explanation:
 | ||
|  | 
 | ||
|  | *   You have to create a program that will convert HTML entities from string to their corresponding HTML entities. There are only a few so you can use different methods. | ||
|  | 
 | ||
|  | ##  Hint: 1
 | ||
|  | 
 | ||
|  | *   You can use regular Expressions however I didn't in this case. | ||
|  | 
 | ||
|  | > _try to solve the problem now_
 | ||
|  | 
 | ||
|  | ##  Hint: 2
 | ||
|  | 
 | ||
|  | *   You will benefit from a chart with all the html entities so you know which ones are the right ones to put. | ||
|  | 
 | ||
|  | > _try to solve the problem now_
 | ||
|  | 
 | ||
|  | ##  Hint: 3
 | ||
|  | 
 | ||
|  | *   You should separate the string and work with each character to convert the right ones and then join everything back up. | ||
|  | 
 | ||
|  | > _try to solve the problem now_
 | ||
|  | 
 | ||
|  | ## Spoiler Alert!
 | ||
|  | 
 | ||
|  |  | ||
|  | 
 | ||
|  | **Solution ahead!** | ||
|  | 
 | ||
|  | ##  Basic Code Solution:
 | ||
|  | ```javascript | ||
|  |     function convertHTML(str) { | ||
|  |       // Split by character to avoid problems. | ||
|  | 
 | ||
|  |       var temp = str.split(''); | ||
|  | 
 | ||
|  |       // Since we are only checking for a few HTML elements I used a switch | ||
|  | 
 | ||
|  |       for (var i = 0; i < temp.length; i++) { | ||
|  |         switch (temp[i]) { | ||
|  |           case '<': | ||
|  |             temp[i] = '<'; | ||
|  |             break; | ||
|  |           case '&': | ||
|  |             temp[i] = '&'; | ||
|  |             break; | ||
|  |           case '>': | ||
|  |             temp[i] = '>'; | ||
|  |             break; | ||
|  |           case '"': | ||
|  |             temp[i] = '"'; | ||
|  |             break; | ||
|  |           case "'": | ||
|  |             temp[i] = "'"; | ||
|  |             break; | ||
|  |         } | ||
|  |       } | ||
|  | 
 | ||
|  |       temp = temp.join(''); | ||
|  |       return temp; | ||
|  |     } | ||
|  | 
 | ||
|  |     //test here | ||
|  |     convertHTML("Dolce & Gabbana"); | ||
|  | ``` | ||
|  | ### Code Explanation:
 | ||
|  | 
 | ||
|  | Explain solution here and add any relevant links | ||
|  | 
 | ||
|  | #### Relevant Links
 | ||
|  | 
 | ||
|  | *   <a href='https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/split' target='_blank' rel='nofollow'>str.split()</a> | ||
|  | *   <a href='https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/join' target='_blank' rel='nofollow'>arr.join()</a> | ||
|  | *   <a href='https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Statements/switch' target='_blank' rel='nofollow'>switch statement</a> | ||
|  | 
 | ||
|  |  <a href='https://repl.it/CLnP/0' target='_blank' rel='nofollow'>Run Code</a> | ||
|  | 
 | ||
|  | ##  Intermediate Code Solution:
 | ||
|  | 
 | ||
|  |     function convertHTML(str) { | ||
|  |     //Chaining of replace method with different arguments | ||
|  |       str = str.replace(/&/g,'&').replace(/</g,'<').replace(/>/g,'>').replace(/"/g,'"').replace(/'/g,"'"); | ||
|  |     return str; | ||
|  |     } | ||
|  | 
 | ||
|  |     // test here | ||
|  |     convertHTML("Dolce & Gabbana"); | ||
|  | 
 | ||
|  |  <a href='https://repl.it/CLnQ/0' target='_blank' rel='nofollow'>Run Code</a> | ||
|  | 
 | ||
|  | ### Code Explanation:
 | ||
|  | 
 | ||
|  | Explain solution here and add any relevant links | ||
|  | 
 | ||
|  | #### Relevant Links
 | ||
|  | 
 | ||
|  | *   <a href='https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace' target='_blank' rel='nofollow'>str.replace()</a> | ||
|  | *   <a href='https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp' target='_blank' rel='nofollow'>Regular Expressions</a> | ||
|  | 
 | ||
|  | ##  Advanced Code Solution:
 | ||
|  | ```javascript | ||
|  |     function convertHTML(str) { | ||
|  |       // Use Object Lookup to declare as many HTML entities as needed. | ||
|  |       htmlEntities={ | ||
|  |         '&':'&', | ||
|  |         '<':'<', | ||
|  |         '>':'>', | ||
|  |         '"':'"', | ||
|  |         '\'':"'" | ||
|  |       }; | ||
|  |       //Use map function to return a filtered str with all entities changed automatically. | ||
|  |       return str.split('').map(entity => htmlEntities[entity] || entity).join(''); | ||
|  |     } | ||
|  | 
 | ||
|  |     // test here | ||
|  |     convertHTML("Dolce & Gabbana"); | ||
|  | ``` | ||
|  |  <a href='https://repl.it/CLnR/0' target='_blank' rel='nofollow'>Run Code</a> | ||
|  | 
 | ||
|  | ### Code Explanation:
 | ||
|  | 
 | ||
|  | *   Create a object to use the Lookup functionality to easily find the characters. | ||
|  | *   Split the original string by characters and use map to check for the changed html entity or use the same one. Alternatively you could use Regex `str.replace(/&|<|>|"|'/gi`. | ||
|  | *   The a function is added which is what returns the converted entity or the original one if there is no conversion. If you go the regex route then you just have to return the matched hits. `return html[entity];` | ||
|  | *   Lastly we join all the characters once again. | ||
|  | 
 | ||
|  | **Note** that if you went the regex route then you don't need to join anything, just make sure you return the whole operation or save it to a variable and then return it. | ||
|  | 
 | ||
|  | #### Relevant Links
 | ||
|  | 
 | ||
|  | *   <a href='https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/split' target='_blank' rel='nofollow'>str.split()</a> | ||
|  | *   <a href='https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map' target='_blank' rel='nofollow'>arr.map()</a> | ||
|  | *   <a href='https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/join' target='_blank' rel='nofollow'>arr.join()</a> | ||
|  | 
 | ||
|  | ##  NOTES FOR CONTRIBUTIONS:
 | ||
|  | 
 | ||
|  | *    **DO NOT** add solutions that are similar to any existing solutions. If you think it is **_similar but better_**, then try to merge (or replace) the existing similar solution. | ||
|  | *   Add an explanation of your solution. | ||
|  | *   Categorize the solution in one of the following categories — **Basic**, **Intermediate** and **Advanced**.  | ||
|  | *   Please add your username only if you have added any **relevant main contents**. ( **_DO NOT_** _remove any existing usernames_) | ||
|  | 
 | ||
|  | > See  <a href='http://forum.freecodecamp.com/t/algorithm-article-template/14272' target='_blank' rel='nofollow'>**`Wiki Challenge Solution Template`**</a> for reference.
 |