Flux(Alt): ReferenceError: localStorage не определен
Я пытаюсь сохранить данные сеанса в localStorage, но получаю сообщение об ошибке. "ReferenceError: localStorage не определено"
Вот код
import alt from '../alt';
import UserActions from '../actions/UserActions.js';
// To Do: Inplement LocalStorage Polyfill
class UserStore {
constructor() {
this.initialize();
this.bindListeners({
onLoginSucceeded: UserActions.LOGIN_SUCCEEDED
});
}
initialize() {
this.setState({
// There's an error here.
_loggedIn: localStorage.getItem('loggedIn'),
_authToken: localStorage.getItem('authToken'),
_userId: localStorage.getItem('userId'),
_profile: localStorage.getItem('profile')
});
}
onLoginSucceeded(data) {
this.setState({
_loggedIn: true,
_authToken: data.authToken,
_userId: data.userId,
_profile: data.profile,
_user: data.user
});
// There's no error here.
localStorage.setItem('authToken', data.authToken);
localStorage.setItem('loggedIn', data.loggedIn);
localStorage.setItem('userId', data.userId);
localStorage.setItem('profile', data.profile);
}
getCurrentUser() {
return this.state._user;
}
isLoggedIn() {
}
}
export default alt.createStore(UserStore, 'UserStore');
Я новичок в es6, поэтому я могу что-то пропустить, но я не смог найти ничего похожего на то, что я не могу вызвать глобальный объект внутри класса. Это полезно, если у вас есть представление об этой ошибке.
[Редактировать] Это работает в es6fiddle http://www.es6fiddle.net/ichmbt0e/
class UserStore {
constructor() {
this.initialize();
}
initialize() {
this.setState({
_loggedIn: localStorage.getItem('loggedIn'),
_authToken: localStorage.getItem('authToken'),
_userId: localStorage.getItem('userId'),
_profile: localStorage.getItem('profile')
});
}
isLoggedIn() {
}
}
1 ответ
Решение
Я обнаружил, что мне нужно использовать Alt.bootstrap при получении данных из localStorage.
// client.js
import 'es6-shim';
import 'whatwg-fetch';
import Iso from 'iso';
import Router from 'react-router';
import React from 'react';
import routes from './client/routes';
import alt from './client/alt';
Iso.bootstrap(function(state, _, container) {
var userStoreData = {
UserStore: {
_loggedIn: localStorage.getItem('loggedIn'),
_authToken: localStorage.getItem('authToken'),
_userId: localStorage.getItem('userId'),
_profile: localStorage.getItem('profile')
}
}
var new_state = Object.assign(JSON.parse(state), userStoreData)
alt.bootstrap(JSON.stringify(new_state));
Router.run(routes, Router.HistoryLocation, function(Handler) {
var node = React.createElement(Handler);
React.render(node, container);
});
});