1. setState() の説明1.1 データの更新setState()はデータを非同期的に更新するために使用されます setState() を複数回呼び出すことができますが、再レンダリングは 1 回だけトリガーされます。 'react' から React をインポートします 'react-dom' から ReactDOM をインポートします。 クラスOppはReact.Componentを拡張します{ 状態 = { カウント: 1, } ハンドルクリック = () => { // データを非同期に更新する this.setState({ カウント: this.state.count + 1, }) this.setState({ カウント: this.state.count + 1, }) console.log(this.state.count) // 1 } 与える() { 戻る ( <div> <h1>カウンター: {this.state.count}</h1> <button onClick={this.handleClick}>+1</button> </div> ) } } ReactDOM.render(<Opp />, document.getElementById('root')) 1.2 推奨構文setState((state, props)=>{})構文を使用する
'react' から React をインポートします 'react-dom' から ReactDOM をインポートします。 クラスOppはReact.Componentを拡張します{ 状態 = { カウント: 1, } ハンドルクリック = () => { /* // データを非同期に更新する this.setState({ カウント: this.state.count + 1, }) console.log(this.state.count) //1 this.setState({ カウント: this.state.count + 1, }) console.log(this.state.count) //1 */ // 推奨構文 this.setState((state, props) => { 戻る { カウント: 状態.count + 1, } }) this.setState((状態、プロパティ) => { console.log('2回目の呼び出し:', state) //2 戻る { カウント: 状態.count + 1, } }) console.log(this.state.count) // 3 } 与える() { 戻る ( <div> <h1>カウンター: {this.state.count}</h1> <button onClick={this.handleClick}>+1</button> </div> ) } } ReactDOM.render(<Opp />, document.getElementById('root')) 1.3 2番目のパラメータ
'react' から React をインポートします 'react-dom' から ReactDOM をインポートします。 クラスOppはReact.Componentを拡張します{ 状態 = { カウント: 1, } ハンドルクリック = () => { this.setState() は、 (状態、プロパティ) => { 戻る { カウント: 状態.count + 1, } }, // 状態が更新されて再レンダリングされた直後に実行します () => { console.log('ステータスの更新が完了しました:', this.state.count) // 2 console.log(document.getElementById('title').innerText) // カウンター: 2 document.title = '更新されたカウントは:' + this.state.count } ) console.log(this.state.count) //1 } 与える() { 戻る ( <div> <h1 id='title'>カウンター: {this.state.count}</h1> <button onClick={this.handleClick}>+1</button> </div> ) } } ReactDOM.render(<Opp />, document.getElementById('root')) 2. JSX構文変換プロセス
'react' から React をインポートします 'react-dom' から ReactDOM をインポートします。 //JSX 構文の変換プロセス// const 要素 = <h1 className='greeting'>Hello JSX</h1> 定数要素 = React.createElement( 'h1', { クラス名: 'greeting', }, 「こんにちは JSX」 ) console.log(要素) ReactDOM.render(要素、document.getElementById('root')) 3. コンポーネント更新メカニズム
4. コンポーネントのパフォーマンス最適化4.1 状態の縮小
4.2 不必要な再レンダリングを避ける
'react' から React をインポートします 'react-dom' から ReactDOM をインポートします。 クラスOppはReact.Componentを拡張します{ 状態 = { カウント: 0, } ハンドルクリック = () => { this.setState((状態) => { 戻る { カウント: this.state.count + 1, } }) } //フック関数 shouldComponentUpdate(nextProps, nextState) { // コンポーネントが再レンダリングされないように false を返します // false を返します // 最新の状態 console.log('latest state', nextState) // 更新前のステータス console.log(this.state) // trueを返すと、コンポーネントは再レンダリングされます。trueを返します。 } 与える() { console.log('コンポーネントが更新されました') 戻る ( <div> <h1>カウンター: {this.state.count}</h1> <button onClick={this.handleClick}>+1</button> </div> ) } } ReactDOM.render(<Opp />, document.getElementById('root')) 例: 乱数 nextState経由 'react' から React をインポートします 'react-dom' から ReactDOM をインポートします。 // 乱数を生成する class Opp extends React.Component { 状態 = { 番号: 0, } ハンドルクリック = () => { this.setState((状態) => { 戻る { 数値: Math.floor(Math.random() * 3)、 } }) } // 2回生成された乱数は同じになる可能性があるため、再レンダリングする必要はありません。shouldComponentUpdate(nextState) { console.log('最新の状態:', nextState, '現在の状態:', this.state) nextState.number !== this.state.number を返します /* if ( nextState.number !== this.state.number) { 真を返す } falseを返す*/ } 与える() { console.log('レンダリング') 戻る ( <div> <h1>乱数: {this.state.number}</h1> <button onClick={this.handleClick}>再生成</button> </div> ) } } ReactDOM.render(<Opp />, document.getElementById('root')) nextState経由 'react' から React をインポートします 'react-dom' から ReactDOM をインポートします。 // 乱数を生成する class Opp extends React.Component { 状態 = { 番号: 0, } ハンドルクリック = () => { this.setState((状態) => { 戻る { 数値: Math.floor(Math.random() * 3)、 } }) } 与える() { 戻る ( <div> <NumberBox number={this.state.number} /> <button onClick={this.handleClick}>再生成</button> </div> ) } } クラス NumberBox は React.Component を拡張します { コンポーネントを更新する必要があります(次のプロパティ) { console.log('最新のプロパティ:', nextProps, '現在のプロパティ:', this.props) nextProps.number !== this.props.number を返します } 与える() { console.log('サブコンポーネントのレンダリング') 戻り値 <h1>乱数: {this.props.number}</h1> } } ReactDOM.render(<Opp />, document.getElementById('root')) 要約するこの記事はこれで終わりです。皆さんのお役に立てれば幸いです。また、123WORDPRESS.COM のその他のコンテンツにも注目していただければ幸いです。 以下もご興味があるかもしれません:
|
<<: MySQL でコミットされていないトランザクションを見つけるための SQL の例の簡単な分析
>>: Dockerコンテナ監視の原理とcAdvisorのインストールおよび使用方法
目次1. インストール2. カプセル化に問題はない3. ファイルを作成する4. アドレス設定をリクエ...
目次01 InnoDBレプリカセットの紹介02 InnoDBレプリカセットの制限03 導入前に知って...
HTML でフォームの送信を無効にする方法は 2 つあります。 1. コントロールタグにreadon...
1. 新しいディスクを準備し、現在のルートパーティションと同じファイルシステムでフォーマットし、ディ...
ステップ準備した静的リソースファイルを指定されたフォルダに配置しますnginx 設定ファイルを変更す...
目次メイントピック1. UbuntuにDockerをインストールする2. DockerにROS2-F...
イメージを構築するイメージを構築するには、主に 2 つの方法があります。実行中のコンテナをイメージに...
図書館運営クエリ1.SHOW DATABASE; ----すべてのデータベースを照会する2. SHO...
目次1. SparkとHadoopの比較1.1 Haoopの欠点1.2 Hadoop MR に対する...
暫定的な応答を示し、要求者に操作の続行を要求するステータス コード。コードの説明100 (続行) リ...
目次1. 要素の表示と非表示を制御する show() hide() 2. 要素の透明度を制御する f...
前の単語line-height、font-size、vertical-align は、インライン要素...
関連記事:初心者が学ぶ HTML タグ (1)初心者は、いくつかの HTML タグを理解することで ...
border-radius で生成できる四角形やその他の図形に影を追加する場合 (「Adaptive...
システムの問題、アプリケーションの速度低下、または原因不明の問題をトラブルシューティングする場合、最...