React

React 라이브러리

youngseokim_kr 2021. 11. 20. 16:08

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