Ошибка - Несоответствие клиент / сервер: 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;

0 ответов

Другие вопросы по тегам