AJAX に反応する


React コンポーネント データは、componentDidMount メソッドで Ajax を介して取得できます。サーバーからデータベースを取得するときに、データを状態に保存し、this.setState メソッドを使用して UI を再レンダリングできます。

データの非同期読み込みを使用する場合は、コンポーネントがアンマウントされる前に、componentWillUnmount を使用して未処理のリクエストをキャンセルします。

次の例は、Github ユーザーから最新の要点共有説明を取得する方法を示しています:

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.js"></script>
    <script src="http://static.php.cn/assets/react/react-0.14.7/build/react-dom.js"></script>
    <script src="http://static.php.cn/assets/react/browser.min.js"></script>
    <script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
  </head>
 <body>
    <div id="example"></div>
    <script type="text/babel">
      var UserGist = React.createClass({
        getInitialState: function() {
          return {
            username: '',
            lastGistUrl: ''
          };
        },

        componentDidMount: function() {
          this.serverRequest = $.get(this.props.source, function (result) {
            var lastGist = result[0];
            this.setState({
              username: lastGist.owner.login,
              lastGistUrl: lastGist.html_url
            });
          }.bind(this));
        },

        componentWillUnmount: function() {
          this.serverRequest.abort();
        },

        render: function() {
          return (
            <div>
              {this.state.username} 用户最新的 Gist 共享地址:
              <a href={this.state.lastGistUrl}>{this.state.lastGistUrl}</a>
            </div>
          );
        }
      });

      ReactDOM.render(
        <UserGist source="https://api.github.com/users/octocat/gists" />,
        document.getElementById('example')
      );
    </script>
  </body>
</html>

Run Instance »

オンラインの例を表示するには、[Run Instance] ボタンをクリックしてください

上記のコードjQuery を使用して Ajax リクエストを完了します。