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

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

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

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

Q&A

解決済

1回答

593閲覧

onClick時に重複していなければ値を配列に追加したい。

alpha95

総合スコア10

React.js

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

0グッド

0クリップ

投稿2021/07/02 04:48

ブルダウンで値を選び、横にあるボタンをクリックした時に、選択しているプルダウンの値(オブジェクト)と同じオブジェクトが配列に入っていなければ追加するという処理を行いたいです。
現在はボタンのonClickで以下のように実装をしています。

const initialRows = { account: {key: 0, value: ""}, building: {key: 0, value: ""}, floor: {key: 0, value: ""}, } const [selectedRows, setSelectedRows] = useState([]); const [selectedRowOfSelect, setSelectedRowOfSelect] = useState(initialRows); //ボタン部分(nameは引数で渡しています) <Button variant="contained" color="primary" onClick={() => {setSelectedRows([...selectedRows,selectedRowOfSelect[name])}} 選択</Button>

ですが、現在は重複している値であっても配列に追加されてしまいます。
イメージとしては
selectedRows = [
{key: 1, value: "アカウント1"}
{key: 3, value: "floor3"}
]
とあったとして{key: 3, value: "floor3"}が入ってこようとした場合は追加できない、{key: 3, value: "アカウント1"}の場合は追加できる
オブジェクトのキーバリューともに一致している場合は追加できないといったイメージです。

上記を実装するためのonClick時の処理をどのように記述をすればよいのかがわからないため教えていただけませんでしょうか。
よろしくお願いいたします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

素直に追加先の配列を走査して、同じkey, valueがないかをチェックすれば良いと思います。
配列にはfind関数があって、条件に合う要素を返してくれます。
なので

js

1const newRow = selectedRowOfSelect[name] 2const dupObject = selectedRows.find((row) => row.key === newRow.key && row.value === newRow.value) 3if (!dupObject) { // 見つからなければundefinedが返る 4 setSelectedRows([...selectedRows, newRow]) 5}

とすればよいかと。

投稿2021/07/03 04:15

p19ljk

総合スコア146

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

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

alpha95

2021/07/10 07:44

回答ありがとうございました。 コメントが遅くなり申し訳ありません。 回答いただいたコードにて意図通りに動かすことができました。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問