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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

React.js

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

Q&A

1回答

1446閲覧

Reactでboolean変数によるオンオフ切り替えができない

good_morning

総合スコア61

Windows 10

Windows 10は、マイクロソフト社がリリースしたOSです。Modern UIを標準画面にした8.1から、10では再びデスクトップ主体に戻され、UIも変更されています。PCやスマホ、タブレットなど様々なデバイスに幅広く対応していることが特徴です。

React.js

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

0グッド

0クリップ

投稿2020/04/20 02:58

現在react上でダイアログ画面上のチェックボックスを使って、localStrageの更新をするプログラムを作成しています。
その仕様は次のとおりです。

(1)ダイアログ画面上のチェックボックスのチェックの有無(true or false)により、localStrageのvalueを切り替える(true or false)。

(2)ダイアログボックスのCancelボタンを押すと、チェックボックスのチェックの有無(true or false)によらず、localStrageのvalueは切り替えない。

(3)ダイアログボックスのUpdateボタンを押すと、チェックボックスのチェックの有無(true or false)をlocalStrageのvalueを設定された値(true or false)に切り替える。

そこで、コンストラクター上でthis.update変数を宣言して、その値がtrueの場合にlocalStrageのvalueを切り替え、その値がfalseの場合にlocalStrageのvalueをそのままにするというしくみにしました。そのしくみを実装したcomponentDidUpdate関数は次のとおりです。

javascript

1 componentDidUpdate(prevProps){ 2 if (this.update == true){ 3 for(let key in this.state ){ 4 window.localStorage.setItem(key, this.state[key]); 5 }; 6 } 7 }

ところが、this.update = falseにしても更新されてしまいます。これは、reactのライフサイクルによるものかもしれません。
どなたか問題点と解決策のわかる方お願いします。

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

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

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

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

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

guest

回答1

0

ところが、this.update = falseにしても更新されてしまいます

this.update == false

ですね

そもそも、boolean値であるなら、

if (this.update){

としましょう。

投稿2020/04/20 04:56

y_waiwai

総合スコア88042

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問