如何在 react.js 中收听 localstorage

Posted

技术标签:

【中文标题】如何在 react.js 中收听 localstorage【英文标题】:How to listen to localstorage in react.js 【发布时间】:2017-09-04 22:03:25 【问题描述】:

我在使用从本地存储中的数组获取数据的组件时遇到问题。它在页面加载时获取初始数据,但是当 localstorage 更改时如何更新?

import React, Component from 'react'; 
    class MovieList extends Component 
       constructor(props)
          super(props)
            this.state = 
            filmList: []     
          
           
      componentWillMount()
          var film = [],
          keys = Object.keys(localStorage),
          i = keys.length;
          while ( i-- ) 
             film.push( localStorage.getItem(keys[i]))     
          
          this.setState(filmList: film)

      ;

      render()
        return(
           <ul>
              <li>this.state.filmlist</li>            
           </ul>

        );
    



export default MovieList;

【问题讨论】:

你无法真正听到本地存储的变化。当您更新本地存储值时,您应该发出一些事件来更新组件的状态。 你如何更改本地存储。 @LeeHanKyeol 这听起来不错。我会试试的。 我不确定如果 localStorage 值的更改源自与侦听器正在运行的同一选项卡,是否会触发该事件... 有人找到解决方案了吗?我需要相同类型的解决方案。 【参考方案1】:

对于遇到此问题的任何人,可以在此处找到“如何收听 localStorage 更改”的答案: https://developer.mozilla.org/en-US/docs/Web/API/StorageEvent

【讨论】:

总结:window.addEventListener('storage',e =&gt; console.log(e)) 然后在不同的选项卡中更改 localStorage【参考方案2】:

根据 Mozilla 的 Web API 文档,只要对 Storage 对象进行更改,就会触发一个 StorageEvent

我在我的应用程序中创建了一个警报组件,只要对特定的localStorage 项目进行更改,该组件就会关闭。我会添加一个代码 sn-p 供您运行,但由于跨域问题,您无法通过它访问 localStorage。

class Alert extends React.Component 
    constructor(props) 
        super(props)
        this.agree = this.agree.bind(this)
        this.disagree = this.disagree.bind(this)
        this.localStorageUpdated = this.localStorageUpdated.bind(this)
        this.state = 
            status: null
        
    
    componentDidMount() 
        if (typeof window !== 'undefined') 
            this.setState(status: localStorage.getItem('localstorage-status') ? true : false)

            window.addEventListener('storage', this.localStorageUpdated)
        
    
    componentWillUnmount()
        if (typeof window !== 'undefined') 
            window.removeEventListener('storage', this.localStorageUpdated)
        
    
    agree()
        localStorage.setItem('localstorage-status', true)
        this.updateState(true)
    
    disagree()
        localStorage.setItem('localstorage-status', false)
        this.updateState(false)
    
    localStorageUpdated()
        if (!localStorage.getItem('localstorage-status')) 
            this.updateState(false)
         
        else if (!this.state.status) 
            this.updateState(true)
        
    
    updateState(value)
        this.setState(status:value)
    
    render () 
        return( !this.state.status ? 
            <div class="alert-wrapper">
                <h3>The Good Stuff</h3>
                <p>Blah blah blah</p>
                <div class="alert-button-wrap">
                    <button onClick=this.disagree>Disagree</button>
                    <button onClick=this.agree>Agree</button>
                </div>
            </div>
         : null )
    

【讨论】:

以上是关于如何在 react.js 中收听 localstorage的主要内容,如果未能解决你的问题,请参考以下文章

如何在 javascript 中收听表单提交事件?

flutter - 如何在 dart/flutter 中收听流值

如何在一个块中收听多个流订阅?

我如何在 Angular 应用程序中订阅/收听 chrome 推送通知

如何在同一视图中收听不同控件上的点击手势?

Firebase:如何停止收听快照