import ReactDom from 'react-dom';
1.리액트 컴포넌트 = HTMLElement 연결하기
import React from 'react'
2. 리액트 컴포넌트 만들기
만들어진 리액트 컴포넌트를 실제 HTMLElement에 연결할 때 ReactDom 라이브러리를 이용합니다.
https://ko.reactjs.org/docs/react-dom.html
https://ko.reactjs.org/docs/react-api.html
Use React, ReactDom Library with CDN
cdn을 통해 리엑트를 사용할 수 있다.
예시
mkdir what-is-react 폴더 만들고
npm init -y
npx serve 로 생성
만들어진다.
https://reactjs.org/docs/cdn-links.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatoble" content="ie=edge" />
<title>Example</title>
</head>
<body>
<script crossorigin src="https://unpkg.com/react@17/umd/react.development.js"></script>
<script crossorigin src="https://unpkg.com/react-dom@17/umd/react-dom.development.js"></script>
<script type="text/javascript">
console.log(React);
console.log(ReactDOM);
</script>
</body>
</html>
이 코드를 body 사이에 넣어준다.
cdn으로 가져와서 사용할 수 있다.
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<meta http-equiv="X-UA-Compatoble" content="ie=edge" />
<title>Example</title>
<style>
*{
margin: 0;
padding: 0;
border: 0;
}
#root p {
color:white;
font-size: 20px;
background-color: green;
text-align: center;
width: 200px;
}
#btn_plus{
background-color: red;
border: 2px solid #000000;
font: size 15px;
width:200px;
}
</style>
</head>
<body>
<div id="root"></div>
<button id="btn_plus">+</button>
<script crossorigin src="https://unpkg.com/react@17/umd/react.development.js"></script>
<script crossorigin src="https://unpkg.com/react-dom@17/umd/react-dom.development.js"></script>
<script type="text/javascript">
console.log(React);
console.log(ReactDOM);
//[[고전방식]]
// const root = document.querySelector('#root');
// const btn_plus = document.querySelector('#btn_plus');
// let i =0;
// root.innerHTNL = "<p>init : 0</p>";
// btn_plus.addEventListener('click',() => {
// root.innerHTML = `<p>init : ${++i}</p>`;
// });
//[[component 사용]]
// const component = {
// message : 'init',
// count:0,
// render(){
// return `<p>${this.message} : ${this.count}</p>`
// }
// };
// function render(rootElement, component) {
// rootElement.innerHTML = component.render();
// }
// //초기화
// render(document.querySelector('#root'),component);
// //클릭
// document.querySelector('#btn_plus').addEventListener('click',()=>{
// component.message = 'update';
// component.count=component.count+1;
// render(document.querySelector('#root'),component);
// })
//[[react 사용]]
const Component = props => {
return React.createElement('p',null,`${props.message} : ${props.count}` ) //<p hello="두번째" > 여기가 세번째 <p/>
}
ReactDOM.render(
React.createElement(Component, {message:'init',count:0}, null),
document.querySelector('#root')
);
//버튼 누르면
document.querySelector('#btn_plus').addEventListener('click', () => {
ReactDOM.render(
React.createElement(Component, {message:'update',count:10}, null),
document.querySelector('#root')
);
})
</script>
</body>
</html>
'React' 카테고리의 다른 글
Event Handing (0) | 2021.11.20 |
---|---|
Props , State (0) | 2021.11.20 |
JSX (0) | 2021.11.20 |
React.createElement로 컴포넌트 만들기 (0) | 2021.11.20 |
React Component (0) | 2021.11.20 |