zoukankan      html  css  js  c++  java
  • React中this指向常用的2种修正方式

    一、使用bind方法(构造函数内绑定)

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="utf-8">
        <title>三大属性之state使用</title>
      </head>
      <body>
        <div id="test1"></div>
      </body>
      <script src="./js/babel.min.js" charset="utf-8"></script>
      <script src="./js/react.development.js" charset="utf-8"></script>
      <script src="./js/react-dom.development.js" charset="utf-8"></script>
      <script type="text/babel">
        // 1.创建虚拟DOM
        class Like extends React.Component {
          constructor(props) {
            super(props);
            this.state = {
              isLike: false
            };
            // 自定义函数中的this默认指向undefined,所以需要修改this的指向
            this.handleClick = this.handleClick.bind(this);
          }
          render(){
            const {isLike} = this.state;
            return <h2 onClick={this.handleClick}>{isLike ? '他喜欢我' : '他不喜欢我'}</h2>;
          }
          handleClick(){
            // 获取状态
            // console.log(this); // undefined
            const isLike = !this.state.isLike;
            // 修改状态
            this.setState({
              isLike
            })
          }
        }
        // 2.渲染
        ReactDOM.render(<Like/>, document.getElementById("test1"));
      </script>
    </html>

    也可以onClick={this.handleClick.bind(this)};这种方法简洁明了,但由于 function函数 在每个render上重新分配,所以有性能影响。

    二、使用箭头函数

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="utf-8">
        <title>三大属性之state使用</title>
      </head>
      <body>
        <div id="test1"></div>
      </body>
      <script src="./js/babel.min.js" charset="utf-8"></script>
      <script src="./js/react.development.js" charset="utf-8"></script>
      <script src="./js/react-dom.development.js" charset="utf-8"></script>
      <script type="text/babel">
        // 1.创建虚拟DOM
        class Like extends React.Component {
          constructor(props) {
            super(props);
            this.state = {
              isLike: false
            };
            // 自定义函数中的this默认指向undefined,所以需要修改this的指向
            // 1.bind 2.箭头函数 3.
            // this.handleClick = this.handleClick.bind(this);
          }
          render(){
            const {isLike} = this.state;
            return <h2 onClick={this.handleClick}>{isLike ? '他喜欢我' : '他不喜欢我'}</h2>;
          }
          // 箭头函数修正this指向
          handleClick = () => {
            // 获取状态
            // console.log(this); // undefined
            const isLike = !this.state.isLike;
            // 修改状态
            this.setState({
              isLike
            })
          }
        }
        // 2.渲染
        ReactDOM.render(<Like/>, document.getElementById("test1"));
      </script>
    </html>

     三、在15版本中,可以使用React.createClass({})创建组件,这样会自动绑定上下文的this

  • 相关阅读:
    C#动态编译计算表达式的值 拓荒者
    Microsoft AJAX Library对 Error的扩展 拓荒者
    在分布式事务(MSDTC)中使用OLE DB数据库连接访问数据 拓荒者
    【转】ExtJS DateField 日期控件Format格式化 拓荒者
    自定义 Web 服务器控件 拓荒者
    Microsoft AJAX Library对 Array的扩展 拓荒者
    (转载)IE 浏览器的创新
    XUnit配置Resharper快捷键
    表现层模式MVC
    读Clean Code 数据结构和对象
  • 原文地址:https://www.cnblogs.com/llcdxh/p/9638149.html
Copyright © 2011-2022 走看看