检测反应中的刷新事件

时间:2016-10-05 22:31:32

标签: reactjs refresh redux

我目前正在使用带有向导形式的react redux。我现在遇到的问题是我需要在表单中保存数据,或者只是刷新数据但让用户知道。

目前,所有内容都存储在多个redux状态中。

有没有办法检测用户的“刷新”事件?我很可能会使用本地存储,但我很好奇第一个选项,并想知道是否可能。

1 个答案:

答案 0 :(得分:4)

如果要检测刷新事件,它与React无关,而是使用名为window.onbeforeunload的纯Javascript事件处理程序

window.onbeforeunload = (e) => {
// I'm about to refresh! do something...
};

但是,我不认为这是存储Redux商店的正确方法,相反,您可以执行以下操作:

// load state from localStorage
const loadState = () => {
  try {
    const serializedState = localStorage.getItem('state');
     if (serializedState === null) {
       return undefined; // reducer will return Redux state, as localstorage is null.
     }
    return JSON.parse(serializedState);
  } catch (err) {
    return undefined;
  }
};

const saveToLocalStorage = (state) => {
  try {
    const serializedState = JSON.stringify(state);
    localStorage.setItem('state', serializedState);
  } catch (err) {
    // ignore error
  }
};

store.subscribe(() => {
  saveToLocalStorage(store.getState()); // save current state to localstorage.
});