Prop `id` did not match. Server: “react-select-17-live-region” Client: “react-select-3-live-region”の原因と対処法

React Selectを実装しようとしたらコンソールでProp id did not match.とエラーが出ていました。今回はその対処法をまとめていきます。

エラー内容

コード例(修正前)

import Select from 'react-select';
const options = [
  { value: 'p1', label: 'Top level - P1' },
  { value: 'p2', label: 'Mid level - P2' },
  { value: 'p3', label: 'Low level - P3' }
];
const Page = () => {
  return (
    <div>
      <h1>Selectbox</h1>
      <Select 
        options={options}
      />
    </div>
  )
}
export default Page;

参考記事をカスタマイズしたものですが、これでも同様のエラーがでるのではないかと思います。

エラー文

Warning: Prop `id` did not match. Server: "react-select-17-live-region" Client: "react-select-3-live-region"
    at span

原因としては、propsとして引き渡す際のidが合致していないこと?によるエラーのようです。Selectコンポーネントでidを渡す必要がありそうですね。

対処法

SelectコンポーネントにinstancedIdを付与することが解決することができました。参考記事にはidの付与も書かれていますが、instancedIdのみの付与で大丈夫でした。

コード例(修正後)

import Select from 'react-select';
const options = [
  { value: 'p1', label: 'Top level - P1' },
  { value: 'p2', label: 'Mid level - P2' },
  { value: 'p3', label: 'Low level - P3' }
];
const Page = () => {
  return (
    <div>
      <h1>Selectbox</h1>
      <Select 
        id="selectbox"
        instanceId="selectbox"
        options={options}
      />
    </div>
  )
}
export default Page;

まとめ

こうしたエラーは英語で調べればすぐ出てくるわけですが、日本語での検索結果も充実してきたら初心者の方にもとっつきやすくなって良いなと思います。こうした記事が少しでもお役に立てたら幸いです。

参考

react-select: How do I resolve “Warning: Prop id did not match”

ー この記事をシェアする? ー

  • Prop `id` did not match. Server: “react-select-17-live-region” Client: “react-select-3-live-region”の原因と対処法

この記事にコメントする

KZ へ返信する コメントをキャンセル

このサイトはreCAPTCHAとGoogleによって保護されています。プライバシーポリシー利用規約が適用されます。