Bagaimanakah Saya Boleh Mengimport Modul ES6 ke dalam Skrip Kandungan Sambungan Chrome Saya?

Barbara Streisand
Lepaskan: 2024-11-24 12:00:19
asal
237 orang telah melayarinya

How Can I Import ES6 Modules into My Chrome Extension's Content Scripts?

Mengimport Modul ES6 dalam Skrip Kandungan untuk Sambungan Chrome

Masalah:

Apabila cuba mengimport modul ES6 dalam Chrome skrip kandungan sambungan menggunakan sintaks import/eksport standard, mesej ralat adalah dihadapi.

Konteks:

Chrome 61 memperkenalkan sokongan untuk modul JavaScript, tetapi sintaks import tidak dikenali dalam skrip kandungan sambungan Chrome.

Penyelesaian: Import Dinamik Asynchronous() Fungsi

Untuk mengimport modul ES6 dalam skrip kandungan sambungan Chrome, gunakan fungsi import() dinamik tak segerak:

(async () => {
  const src = chrome.runtime.getURL("your/content_main.js");
  const contentMain = await import(src);
  contentMain.main();
})();
Salin selepas log masuk

Pertimbangan Tambahan:

  • Isytiharkan skrip yang diimport dalam manifes sambungan sebagai boleh diakses web sumber.
  • Pendekatan ini bergantung pada fungsi tak segerak, yang berkemungkinan disekat oleh pekerja perkhidmatan tapak web.

Penyelesaian "import" segerak

Sebagai alternatif, gunakan skrip bukan modul biasa dan tambahkan namanya pada tatasusunan "js" dalam "content_scripts" sebelum skrip kandungan utama. Pembolehubah global dan fungsi daripada skrip boleh diakses terus.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengimport Modul ES6 ke dalam Skrip Kandungan Sambungan Chrome Saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan