※ これは 2023/05/18 時点の create-react-app@5.0.1 の情報です
最新版では動作が異なる可能性がありますのでご注意ください
前回に引き続き React のチュートリアルの続きを焦らず少しずつ進める
スポンサードリンク
前回作成した index.js
の中で下記の部分を
class Board extends React.Component { renderSquare(i) { return <Square />; }
次のように変更
class Board extends React.Component { renderSquare(i) { return <Square value={i}/>; }
これで renderSquare()
関数の引数 i
が Square クラスの this.props.value
に入ってくるらしい
さらに下記の部分を
class Square extends React.Component { render() { return ( <button className="square"> {/* TODO */} </button> ); } }
次のように変更
class Square extends React.Component { render() { return ( <button className="square"> {this.props.value} </button> ); } }
<button>
が何なのかわからないが、内部に renderSquare(i)
の i
の値が埋め込まれるコードになるらしい
index.js
のコード全体はこうなった
import React from 'react'; import ReactDOM from 'react-dom/client'; import './index.css'; class Square extends React.Component { render() { return ( <button className="square"> {this.props.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 />);
下の方からクラスを入れ子に定義していって、render()
関数で描画するというスタイルらしい
この状態で前回と同じく、VSCode のターミナルから下記コマンドを実行してブラウザで開くと
npm start

なるほど、これでマス目に数字が表示されるようになるらしい