質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

8507閲覧

React.jsにてstateの一部だけ更新する方法

keisukesatomi

総合スコア87

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

2クリップ

投稿2015/09/25 03:31

編集2015/09/25 03:43

###現状
React.jsの初心者です。
React.jsにてインプットテキストを2行使って、入力値が変わる度にstateを使って管理しています。

React.js

1var HeaderFields = React.createClass({ 2 getInitialState: function(){ 3 return {key: "", value: ""}; 4 }, 5 handleChangedKey: function(event){ 6 var tmpValue = this.state.value; 7 this.setState({ 8 key: event.target.value, 9 value: tmpValue 10 }); 11 }, 12 handleChangedValue: function(event){ 13 var tmpKey = this.state.key; 14 this.setState({ 15 key: tmpKey, 16 value: event.target.value 17 }); 18 }, 19 render: function(){ 20 return ( 21 <div> 22 キー<input type="text" onChange={this.handleChangedKey} /> 23 バリュー<input type="text" onChange={this.handleChangedValue} /> 24 </div> 25 ); 26 } 27});

コードの一部を切り出したもので、これらkeyとvalueは別のコンポーネントで利用しています。

###質問
上記ですと、keyとvalueのどちらか片方が変わっただけでも、毎回両方のデータをthis.setState関数でセットしなおしています。

こうではなく、変化したほうのデータだけを更新するような方法はあるのでしょうか?

またはあっても推奨されていないのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

React.jsのsetStateでは、引数として渡されたデータと元々のstateをマージしますので、変更したい片方だけ書けば大丈夫です。変更しない方を削除して、下記のように書いてもちゃんと動作します。

JavaScript

1// 前略 2 handleChangedKey: function(event){ 3 this.setState({ 4 key: event.target.value 5 }); 6 }, 7 handleChangedValue: function(event){ 8 this.setState({ 9 value: event.target.value 10 }); 11 }, 12// 後略

投稿2015/09/25 05:01

編集2015/09/25 05:02
raccy

総合スコア21735

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

keisukesatomi

2015/09/25 05:13

的確なご回答ありがとうございます。 納得いたしました。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問