Mengesan Pemasangan Sambungan Chrome dalam JavaScript
Dalam membina sambungan Chrome, mungkin perlu untuk menentukan sama ada sambungan dipasang dari dalam skrip JavaScript luaran. Ini membantu dalam menyesuaikan kandungan web berdasarkan kehadiran sambungan.
Menurut dokumentasi Chrome, adalah mungkin untuk mencapai ini melalui penghantaran mesej dari tapak web ke sambungan.
Pelaksanaan Kod
Dalam fail background.js sambungan (atau mana-mana skrip bukan kandungan lain), tambahkan mesej pendengar:
chrome.runtime.onMessageExternal.addListener( function(request, sender, sendResponse) { if (request) { if (request.message) { if (request.message == "version") { sendResponse({version: 1.0}); } } } return true; } );
Pendengar ini akan menerima mesej daripada tapak web.
Dari skrip tapak web, hantar mesej ke ID sambungan:
var hasExtension = false; chrome.runtime.sendMessage(extensionId, { message: "version" }, function (reply) { if (reply) { if (reply.version) { if (reply.version >= requiredVersion) { hasExtension = true; } } } else { hasExtension = false; } } );
Semak hasExtension variable untuk menentukan sama ada sambungan dipasang.
Manifest Konfigurasi
Ingat untuk menambah entri pada fail manifest.json, dengan menyatakan domain yang dibenarkan untuk menghantar mesej ke sambungan:
"externally_connectable": { "matches": ["http://mylocalhostextensiontest/*", "http://*:*/*"] },
Sifat Asynchronous dan Pengendalian Ralat
Perhatikan bahawa mekanisme penghantaran mesej adalah tak segerak, jadi anda boleh perlu mengendalikan perkara ini dalam kod anda.
Selain itu, jika sambungan tidak dipasang atau dilumpuhkan, chrome.runtime.sendMessage akan membuang pengecualian. Dalam kes sedemikian, semak chrome.runtime.lastError selepas menghantar mesej:
if (chrome.runtime.lastError) { // Handle the error here... }
Atas ialah kandungan terperinci Bagaimanakah saya boleh mengesan jika sambungan Chrome dipasang menggunakan JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!