state

Tutorial: React基础 Category: React Published: 2026-04-07 13:58:26 Views: 20 Likes: 0 Comments: 0

11_state

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <title>state</title>
  </head>

  <body>
    <!-- 准备好一个"容器" -->
    <div id="test"></div>

    <!-- 引入react核心库 -->
    <script type="text/javascript" src="./js/react.development.js"></script>

    <!-- 引入react-dom, 用于支持react操作DOM -->
    <script
      type="text/javascript"
      src="./js/react-dom.development.js"
    ></script>

    <!-- 引入babel, 用于将jsx转为js -->
    <script type="text/javascript" src="./js/babel.min.js"></script>

    <script type="text/babel">
      // 1.创建组件
      class Weather extends React.Component {
        // 构造器调用几次? ———— 1次
        constructor(props) {
          console.log("constructor");
          super(props);
          // 初始化状态
          this.state = { isHot: false, wind: "微风" };
          // 解决changeWeather中this指向问题 拿过来挂在实例自身上
          this.changeWeather = this.changeWeather.bind(this);
        }

        // render调用几次? ———— 1+n次 1是初始化的那次 n是状态更新的次数
        render() {
          console.log("render");
          //读取状态
          const { isHot, wind } = this.state;
          return (
            <h1 onClick={this.changeWeather}>
              今天天气很{isHot ? "炎热" : "凉爽"}, {wind}
            </h1>
          );
        }

        // changeWeather 在原型对象上
        // changeWeather调用几次? ———— 点几次调几次
        changeWeather() {
          // changeWeather放在哪里? ———— Weather的原型对象上, 供实例使用
          // 由于changeWeather是作为onClick的回调, 所以不是通过实例调用的, 是直接调用
          // 类中的方法默认开启了局部的严格模式, 所以changeWeather中的this为undefined

          console.log("changeWeather");
          // 获取原来的isHot值
          const isHot = this.state.isHot;
          // 严重注意:状态必须通过setState进行更新,且更新是一种合并, 不是替换.
          this.setState({ isHot: !isHot });
          console.log(this);

          // 严重注意:状态(state)不可直接更改, 下面这行就是直接更改!!!
          // this.state.isHot = !isHot //这是错误的写法
        }
      }

      //2.渲染组件到页面
      ReactDOM.render(<Weather />, document.getElementById("test"));
    </script>
  </body>
</html>