【发布时间】:2017-04-13 21:33:17
【问题描述】:
我正在尝试使用 React 和 Redux 构建一个计时器。
我尽可能地分离关注点。请帮我找到一个可行的解决方案!谢谢。
错误:未捕获的类型错误:无法读取未定义(…)的属性“订阅”
定时器组件
Timer.js
import React, { Component } from 'react';
import timer from '../reducers/index.js';
import store from '../stores/timerStore.js';
// React Component to display the timer
class Timer extends Component {
constructor() {
super();
this.start = this.start.bind(this);
this.stop = this.stop.bind(this);
}
start() {
store.dispatch({
type: 'START_TIMER',
offset: Date.now(),
});
}
stop() {
store.dispatch({
type: 'STOP_TIMER'
});
}
format(time) {
const pad = (time, length) => {
while (time.length < length) {
time = '0' + time;
}
return time;
}
time = new Date(time);
let m = pad(time.getMinutes().toString(), 2);
let s = pad(time.getSeconds().toString(), 2);
let ms = pad(time.getMilliseconds().toString(), 3);
return `${m} : ${s} . ${ms}`;
}
render() {
return (
<div>
<h1>Time: {this.format(this.props.time)}</h1>
<button onClick={this.props.isOn ? this.stop : this.start}>
{ this.props.isOn ? 'Stop' : 'Start' }
</button>
</div>
);
}
}
export default Timer;
定时器减速器
timer.js
// Initial state for reducer
const initialState = {
isOn: false,
time: 0
};
function timer(state = initialState, action) {
switch (action.type) {
case 'START_TIMER':
return {
...initialState,
isOn: true,
offset: action.offset,
};
case 'STOP_TIMER':
return {
isOn: false,
time: state.time
};
case 'TICK':
return {
...state,
time: state.time + (action.time - state.offset),
offset: action.time
};
default:
return state;
}
}
export default timer;
定时器存储
timerStore.js
import { createStore } from 'redux';
import timer from '../reducers/index.js';
// Create store using the reducer
export const store = createStore(timer);
主应用组件
index.js
import React, { Component } from 'react';
import ReactDOM from 'react-dom';
import Timer from './components/Timer.js';
import store from './stores/timerStore.js';
const render = () => {
ReactDOM.render(
<Timer
time={store.getState().time}
isOn={store.getState().isOn}
interval={store.getState().interval}
/>,
document.getElementById("app")
);
}
store.subscribe(render);
var interval = null;
store.subscribe(() => {
if (store.getState().isOn && interval === null) {
interval = setInterval(() => {
store.dispatch({
type: 'TICK',
time: Date.now()
});
});
}
if (!store.getState().isOn && interval !== null) {
clearInterval(interval);
interval = null;
}
});
render();
【问题讨论】:
-
您是否得到了文件和行号以及错误信息?
标签: reactjs redux react-redux