' のスクリプトへのアクセスは、オリジン 'null' から CORS ポリシーによってブロックされています。質問する

' のスクリプトへのアクセスは、オリジン 'null' から CORS ポリシーによってブロックされています。質問する

そのため、別の JavaScript ファイルからクラスをインポートしようとすると、コンソールに次のようなエラーが表示されます。

Access to Script at 'file:///home/../.../JavaScript/src/index.js' from origin 'null' has been blocked by CORS policy: Invalid response. Origin 'null' is therefore not allowed access.

私の HTML ファイルでは、次のようにスクリプト ファイルを追加しています。

<script type="module" src="src/index.js"></script>

私の index.js は次のようになります:

import Paddle from "/src/paddle";

let canvas = document.getElementById("gameScreen");
let ctx = canvas.getContext("2d");

const GAME_WIDTH = 800;
const GAME_HEIGHT = 600;

ctx.clearRect(0, 0, GAME_WIDTH, GAME_HEIGHT);
let paddle = new Paddle(GAME_WIDTH, GAME_HEIGHT);

paddle.draw(ctx);

そしてpaddle.js:

export default class Paddle {
    constructor(gameWidth, gameHeight){
        this.width = 150;
        this.height = 30;

        this.position = {
            x: gameWidth/2 - this.width/2,
            y: gameHeight-this.height-10
        }
    }
    draw(ctx){
        ctx.fillRect(this.position.x, this.position.y, this.width, this.height); 
    }
}

私は Chromium ブラウザを使用しています。フォルダ構造は次のようになります:

/javascript
   -/src
       -index.js
       -paddle.js
   -index.html

cors ポリシーを回避する方法を誰か知っていますか?

ベストアンサー1

ES6 モジュールは同一生成元ポリシーの対象です。スクリプトはローカル サーバーから実行する必要があります。ブラウザーでファイルを直接開いても機能しません。

こちらをご覧くださいChrome 62/Chrome Canary 64 での ES6 モジュールのサポート、ローカルでは動作せず、CORS エラー

おすすめ記事