猿问

为什么我的状态迭代被覆盖了?

嗨,所以我不确定为什么我的挂钩中的项目被覆盖并且只有最后一个值保留在其中。


直到我循环遍历 xml 为止,一切正常。钩子setCampgrounds()没有保存所有迭代。我本以为...campgrounds传播会复制上一次迭代,这样它就不会被覆盖。循环中有什么我不理解的东西,或者将这些项目保存在我的露营地挂钩中的正确方法是什么?


const [campgrounds, setCampgrounds] = useState([]);

    

useEffect(() => {

        url = some url...

        axios.get(url)

            .then(res => res.data)

            .then((str) => {

                let newXML = new DOMParser().parseFromString(str, "text/xml");

                let results = newXML.getElementsByTagName("result");

                for (let i = 0; i < results.length; i++) {

                    setCampgrounds([...campgrounds, {

                        facilityID: results[i].getAttribute("facilityID"), 

                        facilityName: results[i].getAttribute("facilityName"),

                        contractID: results[i].getAttribute("contractID")

                    }]);   

                }

            })

            .catch(err => {

                console.log(err);

            })

            

    }, []);


墨色风雨
浏览 131回答 1
1回答

阿波罗的战车

问题campgrounds对于您要排队的每个状态更新,当前状态值都是相同的,因此每个更新都会被下一个更新覆盖,最后一个设置状态的更新是持续存在的更新。解决方案使用功能状态更新对每个更新进行排队。每个入队更新都使用前一个更新的结果状态。功能更新const [campgrounds, setCampgrounds] = useState([]);...for (let i = 0; i < results.length; i++) {  setCampgrounds(campgrounds => [    ...campgrounds,    {      facilityID: results[i].getAttribute("facilityID"),      facilityName: results[i].getAttribute("facilityName"),      contractID: results[i].getAttribute("contractID")    }  ]);}
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答