※ これは 2023/05/18 時点の create-react-app@5.0.1 の情報です
最新版では動作が異なる可能性がありますのでご注意ください
前回に引き続き React のチュートリアルの続きを焦らず少しずつ進める
スポンサードリンク
前回作成した index.js
の中で下記の部分を
class Board extends React.Component { renderSquare(i) { return <Square value={i}/>; }
下記のような感じに変更
class Board extends React.Component { constructor(props) { super(props); this.state = { squares: Array(9).fill(null), }; } renderSquare(i) { return <Square value={this.state.squares[i]} />; }
Board
にコンストラクタを追加して 、state.squares
に null
配列を9つ設定して初期化するように変更
Square.value
には Board
の state.squares
の配列の値を渡すようにした
この時点で全体のコードはこんな感じ
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 { constructor(props) { super(props); this.state = { squares: Array(9).fill(null), }; } renderSquare(i) { return <Square value={this.state.squares[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
前回と動作自体は変わらずリファクタリングしただけ
ただ、React は単方向データバインディングらしいので、クリックして X になったところは Board
の state.squares
には反映されないようだ