1. ホーム
  2. reactjs

[解決済み] ReactJS - SCRIPT1010: 期待される識別子 - IE11 で本番ビルドが実行されない

2022-02-14 20:24:10

質問

今日、create-react-appで新しいプロジェクトを作成しました。本番ビルドはIE11で正常に動作せず、コンソールに以下のエラーが表示されます。

SCRIPT1010: Expected identifier

main.jsの中で指している行です。

{var n=e&&e.__esModule?function(){return e.default}:function(){return e};

上記e.(default)の後がエラーになります。私のパッケージのjsonはプレーンです。

{
  "name": "sample-app",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "react": "^16.3.1",
    "react-dom": "^16.3.1",
    "react-scripts": "1.1.4"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test --env=jsdom",
    "eject": "react-scripts eject"
  }
}

不思議なことに、私の開発サーバーはIE11で完全に動作するので、問題は本番ビルドに限ったことなのです。Chromeでも問題なく動作しています。ポリフィルが必要なのでしょうか?

解決方法は?

以下は、私が修正した方法です。React氏 "Dan Abramov"が手伝ってくれたのは言うまでもありません。

つまり、デフォルトではアプリケーションはIE7でレンダリングされ、トランスパイルビルドをサポートするIE11/EDGEだけではレンダリングされないという問題です。そこで、意図するブラウザが IE11/edge であることをブラウザに知らせるために、メタ情報に言及する必要がありました。これを head の部分を削除してください。

<meta http-equiv="X-UA-Compatible" content="IE=edge">

今、私が得たように、あなたはまた、コンソールにいくつかのエラーが表示されます。

SCRIPT5009: 'Set' is undefined

心配しないでください、それを回避する方法もあるのです。 https://reactjs.org/docs/javascript-environment-requirements.html

以下は、Danとgit上で議論した問題です。 https://github.com/facebook/create-react-app/issues/4255