Keadaan Bertindakbalas(keadaan)


React menganggap komponen sebagai mesin keadaan. Dengan berinteraksi dengan pengguna, keadaan berbeza dicapai, dan kemudian UI diberikan untuk memastikan antara muka pengguna dan data konsisten.

Dalam React, anda hanya perlu mengemas kini keadaan komponen, dan kemudian memaparkan semula antara muka pengguna berdasarkan keadaan baharu (tanpa memanipulasi DOM).

Komponen LikeButton dibuat dalam contoh berikut Kaedah getInitialState digunakan untuk mentakrifkan keadaan awal, iaitu objek ini boleh dibaca melalui sifat this.state. Apabila pengguna mengklik pada komponen, menyebabkan keadaan berubah, kaedah this.setState mengubah nilai keadaan Selepas setiap pengubahsuaian, kaedah this.render dipanggil secara automatik untuk memaparkan komponen semula.

Instance

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8" />
    <title>php中文网 React 实例</title>
    <script src="http://static.php.cn/assets/react/react-0.14.7/build/react.min.js"></script>
    <script src="http://static.php.cn/assets/react/react-0.14.7/build/react-dom.min.js"></script>
    <script src="http://static.php.cn/assets/react/browser.min.js"></script>
  </head>
  <body>
    <div id="example"></div>
    <script type="text/babel">
      var LikeButton = React.createClass({
        getInitialState: function() {
          return {liked: false};
        },
        handleClick: function(event) {
          this.setState({liked: !this.state.liked});
        },
        render: function() {
          var text = this.state.liked ? '喜欢' : '不喜欢';
          return (
            <p onClick={this.handleClick}>
              你<b>{text}</b>我。点我切换状态。
            </p>
          );
        }
      });

      React.render(
        <LikeButton />,
        document.getElementById('example')
      );
    </script>
  </body>
</html>

Run Instance»

Klik butang "Run Instance" untuk melihat contoh dalam talian