153 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			153 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
|   | --- | ||
|  | id: 5ddb965c65d27e1512d44db5 | ||
|  | title: Part 30 | ||
|  | challengeType: 0 | ||
|  | dashedName: part-30 | ||
|  | --- | ||
|  | 
 | ||
|  | # --description--
 | ||
|  | 
 | ||
|  | Next, we will create a text node that we will later append to the `result` element. | ||
|  | 
 | ||
|  | JavaScript has a function called `createTextNode()` to accomplish this. For example: | ||
|  | 
 | ||
|  | ```js | ||
|  | const myText = document.createTextNode("Hello world!") | ||
|  | ``` | ||
|  | 
 | ||
|  | Create a variable named `resultText` and set it equal to a text node. Leave the string empty for now. | ||
|  | 
 | ||
|  | # --hints--
 | ||
|  | 
 | ||
|  | See description above for instructions. | ||
|  | 
 | ||
|  | ```js | ||
|  | assert( | ||
|  |   /const\s*resultText\s*=\s*document\.createTextNode\([\'\"\`]?\s*[\'\"\`]?\)/.test( | ||
|  |     code | ||
|  |   ) | ||
|  | ); | ||
|  | ``` | ||
|  | 
 | ||
|  | # --seed--
 | ||
|  | 
 | ||
|  | ## --before-user-code--
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <!DOCTYPE html> | ||
|  | <html> | ||
|  |   <head> | ||
|  |     <meta charset="utf-8" /> | ||
|  |     <title></title> | ||
|  |     <meta name="description" content="" /> | ||
|  |     <meta name="viewport" content="width=device-width, initial-scale=1" /> | ||
|  |     <link rel="stylesheet" href="styles.css" /> | ||
|  |   </head> | ||
|  |   <body> | ||
|  |     <div class="container"> | ||
|  |       <form id="calorie-form"> | ||
|  |         <h2 class="center">Calorie Counter</h2> | ||
|  |         <div class="grid"> | ||
|  |           <legend>Sex</legend> | ||
|  |           <div> | ||
|  |             <input type="radio" name="sex" id="female" value="F" checked /> | ||
|  |             <label for="female"> | ||
|  |               Female (2,000 calories) | ||
|  |             </label> | ||
|  | 
 | ||
|  |             <div> | ||
|  |               <input type="radio" name="sex" id="male" value="M" /> | ||
|  |               <label for="male"> | ||
|  |                 Male (2,500 calories) | ||
|  |               </label> | ||
|  |             </div> | ||
|  |           </div> | ||
|  |         </div> | ||
|  |         <div class="grid" id="entries"> | ||
|  |           Breakfast | ||
|  |           <input | ||
|  |             type="number" | ||
|  |             min="0" | ||
|  |             class="cal-control" | ||
|  |             id="breakfast" | ||
|  |           /><br /> | ||
|  |           Lunch | ||
|  |           <input type="number" min="0" class="cal-control" id="lunch" /><br /> | ||
|  |           Dinner <input type="number" min="0" class="cal-control" id="dinner" /> | ||
|  |         </div> | ||
|  |         <button type="button" class="btn-add" id="add"> | ||
|  |           Add Entry | ||
|  |         </button> | ||
|  |         <button type="submit" class="btn-solid" id="calculate"> | ||
|  |           Calculate | ||
|  |         </button> | ||
|  |         <button type="button" class="btn-outline" id="clear"> | ||
|  |           Clear | ||
|  |         </button> | ||
|  |       </form> | ||
|  |       <div id="output"></div> | ||
|  |     </div> | ||
|  |   </body> | ||
|  | </html> | ||
|  | ``` | ||
|  | 
 | ||
|  | ## --after-user-code--
 | ||
|  | 
 | ||
|  | ```html | ||
|  |   </body> | ||
|  | </html> | ||
|  | ``` | ||
|  | 
 | ||
|  | ## --seed-contents--
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <script> | ||
|  |   document.getElementById('calorie-form').onsubmit = calculate; | ||
|  | 
 | ||
|  |   function calculate(e) { | ||
|  |     e.preventDefault(); | ||
|  | 
 | ||
|  |     const total = Array.from(document.getElementsByClassName('cal-control')) | ||
|  |       .map(meal => Number(meal.value)) | ||
|  |       .reduce((accumulator, currentValue) => accumulator + currentValue, 0); | ||
|  | 
 | ||
|  |     const maxCalories = document.getElementById('female').checked ? 2000 : 2500; | ||
|  | 
 | ||
|  |     const difference = total - maxCalories; | ||
|  | 
 | ||
|  |     const surplusOrDeficit = difference > 0 ? 'Surplus' : 'Deficit'; | ||
|  | 
 | ||
|  |     const output = document.getElementById('output'); | ||
|  | 
 | ||
|  |     const result = document.createElement('h3'); | ||
|  |   } | ||
|  | </script> | ||
|  | ``` | ||
|  | 
 | ||
|  | # --solutions--
 | ||
|  | 
 | ||
|  | ```html | ||
|  | <script> | ||
|  |   document.getElementById('calorie-form').onsubmit = calculate; | ||
|  | 
 | ||
|  |   function calculate(e) { | ||
|  |     e.preventDefault(); | ||
|  | 
 | ||
|  |     const total = Array.from(document.getElementsByClassName('cal-control')) | ||
|  |       .map(meal => Number(meal.value)) | ||
|  |       .reduce((accumulator, currentValue) => accumulator + currentValue, 0); | ||
|  | 
 | ||
|  |     const maxCalories = document.getElementById('female').checked ? 2000 : 2500; | ||
|  | 
 | ||
|  |     const difference = total - maxCalories; | ||
|  | 
 | ||
|  |     const surplusOrDeficit = difference > 0 ? 'Surplus' : 'Deficit'; | ||
|  | 
 | ||
|  |     const output = document.getElementById('output'); | ||
|  | 
 | ||
|  |     const result = document.createElement('h3'); | ||
|  |     const resultText = document.createTextNode(); | ||
|  |   } | ||
|  | </script> | ||
|  | ``` |