Ошибка - Несоответствие клиент / сервер: React, Redux, NextJS, Typescript и стилизованные компоненты
Я пытался работать над примером Counter, используя Next.js для SSR, Typescript и Styled Components. У меня есть в основном рабочий пример на Github: https://github.com/dwaynelavon/nextscript-boilerplate
Проблема в том, что я продолжаю получать ошибки о несоответствии клиента и сервера. Warning: Text content did not match. Server: "1" Client: "0"
, Я не могу понять, в чем проблема. Какие-либо предложения?
// Index.tsx
type CounterDispatchProps = {
addCount: () => any;
startClock: () => any;
};
type CounterStateProps = {
lastUpdate: number;
light: boolean;
};
class Counter extends React.Component<
CounterDispatchProps & CounterStateProps
> {
private timer: number;
constructor(props: CounterDispatchProps & CounterStateProps) {
super(props);
}
static getInitialProps(props: any) {
const store = props['store'];
const isServer = props['isServer'];
store.dispatch(serverRenderClock(isServer));
store.dispatch(addCount());
return { isServer };
}
componentDidMount() {
this.timer = this.props.startClock();
}
componentWillUnmount() {
clearInterval(this.timer);
}
render() {
const props = {
title: 'Index Page!',
linkTo: '/other',
lastUpdate: this.props.lastUpdate,
light: this.props.light
};
return <Page {...props} />;
}
}
const mapDispatchToProps = (dispatch: any) => {
return {
addCount: bindActionCreators(addCount, dispatch),
startClock: bindActionCreators(startClock, dispatch)
};
};
const mapStateToProps = (state: any) => {
return {
lastUpdate: state['lastUpdate'],
light: state['light']
};
};
export default withRedux(initStore, mapStateToProps,
mapDispatchToProps)(Counter);
Вот компонент страницы:
Interface PageProps {
title: string;
linkTo: string;
lastUpdate: number;
light: boolean;
}
const Page = ({ title, linkTo, lastUpdate, light }: PageProps) => {
const clockProps = {
lastUpdate,
light
};
return (
<div>
<h1>{title}</h1>
<Clock {...clockProps} />
<AddCount />
<nav>
<Link href={linkTo}>
<a>Navigate</a>
</Link>
</nav>
</div>
);
};
export default Page;