ReactとReduxでタイマーを作成しようとしています。ReactJS:Uncaught TypeError:未定義(...)のプロパティ 'subscribe'を読み取ることができません。
私は可能な限り懸念事項を分けています。私は実際の解決策を見つけるのを助けてください!ありがとうございました。
エラー:キャッチされない例外TypeError:プロパティを読んで、未定義の '購読' することはできません(...)
タイマーコンポーネント
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);
メインアプリケーションコンポーネント次の2つの異なる問題持っている
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();
エラーと一緒にファイルと行番号を取得しましたか? –