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

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

新規登録して質問してみよう
ただいま回答率
85.50%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

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

Q&A

解決済

1回答

1305閲覧

【React】要素に配列を持つオブジェクトの中身をuseStateで更新したい

tenten11055

総合スコア67

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

React.js

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

0グッド

1クリップ

投稿2022/08/15 02:15

実現したいこと

タイトル通りなのですが、要素に配列を持つオブジェクトの中身をsetStateで更新する方法を教えていただきたいです。
更新の内容は配列の中にチェックボックスのvalueを追加・削除したいです。

js

1const defaultState = { 2 hoges: [] 3} 4 5const [state, setState] = useState(defaultState) 6const updateState = (event) => { 7 setState(ここをどう書くか) 8 // { hoges: ['huga', 'piyo'] } -> setStateするごとに配列の中身が増えていくイメージ 9}

単に要素の中身を更新するなら↓

js

1setState({ ...state, [event.target.name]: event.target.value })

シンプルな配列にvalueを追加・削除するなら↓

js

1const [state, setState] = useState([]) 2if (event.target.checked) { 3 setState([...state, event.target.value]) 4 return 5} 6setState( 7 state.filter((v) => v !== event.target.value) 8)

だと思うのですが、オブジェクト内の配列となった時の更新方法がいまいち分かりません。
どなたか教えていただけると幸いです。
よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

まず、既存の値を使って更新を行いたい場合、関数を使いましょう。

そして、「要素の中身を更新するなら」の応用で、配列も更新できます。

javascript

1setState(old => ({...old, hoges: [...old.hoges, e.target.value]}))

投稿2022/08/15 02:52

maisumakun

総合スコア145121

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

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

tenten11055

2022/08/15 16:51

勉強になりました。 ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問