* feat(tools): add seed/solution restore script * chore(curriculum): remove empty sections' markers * chore(curriculum): add seed + solution to Chinese * chore: remove old formatter * fix: update getChallenges parse translated challenges separately, without reference to the source * chore(curriculum): add dashedName to English * chore(curriculum): add dashedName to Chinese * refactor: remove unused challenge property 'name' * fix: relax dashedName requirement * fix: stray tag Remove stray `pre` tag from challenge file. Signed-off-by: nhcarrigan <nhcarrigan@gmail.com> Co-authored-by: nhcarrigan <nhcarrigan@gmail.com>
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| ---
 | |
| id: 5a24bbe0dba28a8d3cbd4c5f
 | |
| title: Render HTML Elements to the DOM
 | |
| challengeType: 6
 | |
| forumTopicId: 301406
 | |
| dashedName: render-html-elements-to-the-dom
 | |
| ---
 | |
| 
 | |
| # --description--
 | |
| 
 | |
| So far, you've learned that JSX is a convenient tool to write readable HTML within JavaScript. With React, we can render this JSX directly to the HTML DOM using React's rendering API known as ReactDOM.
 | |
| 
 | |
| ReactDOM offers a simple method to render React elements to the DOM which looks like this: `ReactDOM.render(componentToRender, targetNode)`, where the first argument is the React element or component that you want to render, and the second argument is the DOM node that you want to render the component to.
 | |
| 
 | |
| As you would expect, `ReactDOM.render()` must be called after the JSX element declarations, just like how you must declare variables before using them.
 | |
| 
 | |
| # --instructions--
 | |
| 
 | |
| The code editor has a simple JSX component. Use the `ReactDOM.render()` method to render this component to the page. You can pass defined JSX elements directly in as the first argument and use `document.getElementById()` to select the DOM node to render them to. There is a `div` with `id='challenge-node'` available for you to use. Make sure you don't change the `JSX` constant.
 | |
| 
 | |
| # --hints--
 | |
| 
 | |
| The constant `JSX` should return a `div` element.
 | |
| 
 | |
| ```js
 | |
| assert(JSX.type === 'div');
 | |
| ```
 | |
| 
 | |
| The `div` should contain an `h1` tag as the first element.
 | |
| 
 | |
| ```js
 | |
| assert(JSX.props.children[0].type === 'h1');
 | |
| ```
 | |
| 
 | |
| The `div` should contain a `p` tag as the second element.
 | |
| 
 | |
| ```js
 | |
| assert(JSX.props.children[1].type === 'p');
 | |
| ```
 | |
| 
 | |
| The provided JSX element should render to the DOM node with id `challenge-node`.
 | |
| 
 | |
| ```js
 | |
| assert(
 | |
|   document.getElementById('challenge-node').childNodes[0].innerHTML ===
 | |
|     '<h1>Hello World</h1><p>Lets render this to the DOM</p>'
 | |
| );
 | |
| ```
 | |
| 
 | |
| # --seed--
 | |
| 
 | |
| ## --seed-contents--
 | |
| 
 | |
| ```jsx
 | |
| const JSX = (
 | |
|   <div>
 | |
|     <h1>Hello World</h1>
 | |
|     <p>Lets render this to the DOM</p>
 | |
|   </div>
 | |
| );
 | |
| // Change code below this line
 | |
| ```
 | |
| 
 | |
| # --solutions--
 | |
| 
 | |
| ```jsx
 | |
| const JSX = (
 | |
| <div>
 | |
|   <h1>Hello World</h1>
 | |
|   <p>Lets render this to the DOM</p>
 | |
| </div>
 | |
| );
 | |
| // Change code below this line
 | |
| ReactDOM.render(JSX, document.getElementById('challenge-node'));
 | |
| ```
 |