У меня есть код ниже, где я хочу создать список тегов. В этом примере я выбираю список тегов в setAllTags()
, а затем количество доступных тегов в setAvailableTags()
.
Тогда у меня проблема в том, что при запуске setAvailableTags()
он удаляет теги, которые были извлечены в setAllTags()
. Кажется, что состояние, которое я установил в setAllTags()
, не используется, когда setAvailableTags()
- это настройки.
Есть идеи, что я могу сделать, чтобы это исправить?
https://codesandbox.io/s/rj40lz6554
import React, { useState, useEffect } from "react";
import ReactDOM from "react-dom";
const Search = () => {
const [tags, setTags] = useState({
all: [],
available: []
});
const setAllTags = () => {
const all = ["tag 1", "tag 2", "tag 3"];
const newValue = {
...tags,
all
};
console.log("setting all tags to ", newValue);
setTags(newValue);
};
const setAvailableTags = () => {
const available = ["tag 1", "tag 2"];
const newValue = {
...tags,
available
};
console.log("setting available tags to", newValue);
setTags(newValue);
};
useEffect(setAllTags, []);
useEffect(setAvailableTags, []);
return (
<div>
<div>
<select placeholder="Tags">
{tags.all.map((tag, i) => (
<option key={tag + i} value={tag}>
{tag}
</option>
))}
</select>
</div>
</div>
);
};
const App = () => {
return (
<div>
<h1>Hello React!</h1>
<Search />
</div>
);
};
ReactDOM.render(<App />, document.getElementById("app"));
Консоль зарегистрирована с
setting all tags to Object {all: Array[3], available: Array[0]}
setting available tags to Object {all: Array[0], available: Array[2]}