3 回答
TA贡献1850条经验 获得超11个赞
每当 JSON.parse() 收到无效字符串时,React 就会抛出跨域错误,您应该能够使用以下命令重新创建它JSON.parse('')
。为什么 React 允许这种情况发生,我有自己的看法,但是您需要编写一些可以 JSON.parse() 的内容,以便localStorage.getItem('user_data')
您的代码正常工作。您应该看到console.log(this.state.healthData)
它不是有效的 JSON 字符串。
TA贡献1827条经验 获得超8个赞
我尝试这样做,效果很完美。
您必须确保状态已更改。(通过回调/useEffect)
test = () => {
const data = {
age: "20",
gender: "male",
goal: "recomp",
height: "181",
weight: "80"
};
localStorage.setItem("user_data", JSON.stringify(data));
this.setState(
{
healthData: JSON.parse(localStorage.getItem("user_data"))
},
() => {
console.log(this.state.healthData);
}
);
};
TA贡献1852条经验 获得超1个赞
所以我简单地通过在构造函数中设置状态而不是在组件 didMount 上设置状态来解决我的问题,但我不知道为什么当它的代码完全相同时它会起作用?
constructor(props) {
super(props);
this.state = {
healthData: (JSON.parse(localStorage.getItem('user_data')))
}
}
- 3 回答
- 0 关注
- 138 浏览
添加回答
举报