React基础巩固(五)——基础案例
 
基础案例一:电影列表
 
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>电影列表</title>
  </head>
  <body>
    <div id="root"></div>
    <script
      crossorigin
      src="https://unpkg.com/react@18/umd/react.development.js"
    ></script>
    <script
      crossorigin
      src="https://unpkg.com/react-dom@18/umd/react-dom.development.js"
    ></script>
    <script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>
    <script type="text/babel">
      
      const root = ReactDOM.createRoot(document.querySelector("#root"));
      
      class App extends React.Component {
        
        constructor() {
          super();
          this.state = {
            movies: [
              "星际穿越",
              "流浪地球",
              "独行月球",
              "大话西游",
              "火星救援",
            ],
          };
        }
        
        render() {
          
          
          
          
          
          
          
          
          
          
          
          
          return (
            <div>
              <h2>电影列表</h2>
              <ul>
                {this.state.movies.map((movie) => (
                  <li>{movie}</li>
                ))}
              </ul>
            </div>
          );
        }
      }
      
      root.render(<App />);
    </script>
  </body>
</html>
 
基础案例二:计数器
 
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>计数器</title>
  </head>
  <body>
    <div id="root"></div>
    <script
      crossorigin
      src="https://unpkg.com/react@18/umd/react.development.js"
    ></script>
    <script
      crossorigin
      src="https://unpkg.com/react-dom@18/umd/react-dom.development.js"
    ></script>
    <script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>
    <script type="text/babel">
      
      const root = ReactDOM.createRoot(document.querySelector("#root"));
      
      class App extends React.Component {
        
        constructor() {
          super();
          this.state = {
            counter: 100,
          };
          this.increment = this.increment.bind(this);
          this.decrement = this.decrement.bind(this);
        }
        
        
        increment() {
          this.setState({
            counter: this.state.counter + 1,
          });
        }
        
        decrement() {
          this.setState({
            counter: this.state.counter - 1,
          });
        }
        
        render() {
          const { counter } = this.state;
          return (
            <div>
              <h2>当前计数:{counter}</h2>
              <button onClick={this.decrement}>-1</button>
              <button onClick={this.increment}>+1</button>
            </div>
          );
        }
      }
      
      root.render(<App />);
    </script>
  </body>
</html>