※ これは 2023/05/18 時点の create-react-app@5.0.1 の情報です
最新版では動作が異なる可能性がありますのでご注意ください
前回に引き続き React のチュートリアルの続きを焦らず少しずつ進める
スポンサードリンク
前回作成した index.js
の中で下記の部分を
class Square extends React.Component { render() { return ( <button className="square" onClick={() => console.log('click')}> {this.props.value} </button> ); } }
下記のような感じに変更
class Square extends React.Component { constructor(props) { super(props); this.state = { value: null, }; } render() { return ( <button className="square" onClick={() => this.setState({value: 'X'})} > {this.state.value} </button> ); } }
コンストラクタを呼び出してまず規定クラスのコンストラクタ呼び出し、state.value
に null
を設定する
この state はセッション情報みたいなものらしい
マスがクリックされたら setState()
で state.value
に X
を設定、マスの内部に state.value
を表示する
setState()
が呼ばれたら内部を再レンダーして表示更新するとのこと
どんな場合に表示更新されるのかまだよくわからない
この時点で全体のコードはこんな感じ
import React from 'react'; import ReactDOM from 'react-dom/client'; import './index.css'; class Square extends React.Component { constructor(props) { super(props); this.state = { value: null, }; } render() { return ( <button className="square" onClick={() => this.setState({value: 'X'})} > {this.state.value} </button> ); } } class Board extends React.Component { renderSquare(i) { return <Square value={i}/>; } render() { const status = 'Next player: X'; return ( <div> <div className="status">{status}</div> <div className="board-row"> {this.renderSquare(0)} {this.renderSquare(1)} {this.renderSquare(2)} </div> <div className="board-row"> {this.renderSquare(3)} {this.renderSquare(4)} {this.renderSquare(5)} </div> <div className="board-row"> {this.renderSquare(6)} {this.renderSquare(7)} {this.renderSquare(8)} </div> </div> ); } } class Game extends React.Component { render() { return ( <div className="game"> <div className="game-board"> <Board /> </div> <div className="game-info"> <div>{/* status */}</div> <ol>{/* TODO */}</ol> </div> </div> ); } } // ======================================== const root = ReactDOM.createRoot(document.getElementById("root")); root.render(<Game />);
これを実行、VSCode のターミナルから下記コマンドを実行してブラウザで開く
npm start
確かにクリックしたマスが X になった