javascript - 通过本地存储设置时, react 状态仍在变化

标签 javascript reactjs local-storage

基本上我有两个按钮,都将我的 this.state.language 更改为“en”或“es”。我创建了 2 个 onClick 方法,以便在更改它时将其保存到本地存储。但是,执行此操作后,当我转到其他页面时,状态将恢复为默认值。

constructor(){
    super();
    this.state = {
      sideNav: '',
      language: ''
    }
    this.langEn = this.langEn.bind(this);
    this.langEs = this.langEs.bind(this);
  }

  langEn() {
    this.setState({language: 'en'});
    localStorage.setItem('language', JSON.stringify(this.state.language));
    console.log(this.state);
  }

  langEs() {
    this.setState({language: 'es'});
    localStorage.setItem('language', JSON.stringify(this.state.language));
    console.log(this.state);
  }

语言状态也作为 Prop 传递到我的路由中

最佳答案

状态是异步,您可以在状态值更新后调用函数,尝试如下:

   langEn() {
    this.setState({language: 'en'}, () => localStorage.setItem('language', JSON.stringify(this.state.language)));
  }

这在 setState 的文档中进行了解释。

setState() does not immediately mutate this.state but creates a pending state transition. Accessing this.state after calling this method can potentially return the existing value. There is no guarantee of synchronous operation of calls to setState and calls may be batched for performance gains.

您的控制台和本地存储无法设置。

关于javascript - 通过本地存储设置时, react 状态仍在变化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55003372/

相关文章:

javascript - 使用 foreach 将 id/class 放入 HTML 中以获得确切值的正确方法?

javascript - 加速改变 div 元素颜色的 JavaScript 函数构造 'led display'

reactjs - 在 React 映射循环中连接 className 值

javascript - 使用本地存储存储和显示多个答案

javascript - 检查对象是否在 localStorage 中的 AngularJS 数组中

javascript - 保存当前页面状态javascript

javascript - 解析JSON无法获取菜单项的名称

javascript - 下拉切换不响应键盘命令

reactjs - 返回 reducer 结果集合的 reducer

javascript - "Slots"prop 在 Material -ui Slider 组件上应用时不执行任何操作