Heim > Web-Frontend > js-Tutorial > Wie greife ich über Inhaltsskripts in Chrome-Erweiterungen auf globale Variablen zu?

Wie greife ich über Inhaltsskripts in Chrome-Erweiterungen auf globale Variablen zu?

Patricia Arquette
Freigeben: 2024-10-26 05:45:02
Original
659 Leute haben es durchsucht

How to Access Global Variables from Content Scripts in Chrome Extensions?

Zugriff auf globale Variablen aus Inhaltsskripten in Chrome-Erweiterungen

Trotz Versuchen, die GLOBALS-Variable aus der aktuellen Gmail-Nachricht über jQuery.load abzurufen( ) in einem Inhaltsskript bleiben Fehler aufgrund der Isolation bestehen.

Lösung: Skriptinjektion und Ereignis-Listener

Um auf globale Eigenschaften des Seitenfensters zuzugreifen, sollten Sie Folgendes verwenden:

  1. Skriptinjektion:Einfügung eines neuen Skriptelements in den Kontext der Seite:
var s = document.createElement('script');
s.src = chrome.extension.getURL('script.js');
(document.head||document.documentElement).appendChild(s);
Nach dem Login kopieren

Sobald das Skript geladen ist, entfernen Sie es aus Gründen der Sauberkeit:

s.onload = function() {
    s.remove();
};
Nach dem Login kopieren
  1. Ereignis-Listener:Verwenden Sie Ereignis-Listener, um Daten zu übertragen:
document.addEventListener('RW759_connectExtension', function(e) {
    // e.detail contains transferred data, e.g., GLOBALS
});
Nach dem Login kopieren

Beispielcode:

contentscript.js (Am Dokumentende ausführen):

// Inject script
var s = document.createElement('script');
s.src = chrome.extension.getURL('script.js');
(document.head||document.documentElement).appendChild(s);

// Event listener
document.addEventListener('RW759_connectExtension', function(e) {
    alert(e.detail); // Access GLOBALS
});
Nach dem Login kopieren

script.js ("run_at": "document_end" im Manifest):

setTimeout(function() {
    document.dispatchEvent(new CustomEvent('RW759_connectExtension', {
        detail: GLOBALS // Send data
    }));
}, 0);
Nach dem Login kopieren

Denken Sie daran, „script.js“ zum Abschnitt „web_accessible_resources“ in der Manifestdatei hinzuzufügen.

Best Practice:

Injizierte Logik minimieren Skripte und übernehmen die meiste Verarbeitung im Inhaltsskript, um die Zuverlässigkeit der Erweiterung und den Zugriff auf zusätzliche Funktionen wie Chrome.*-APIs sicherzustellen.

Das obige ist der detaillierte Inhalt vonWie greife ich über Inhaltsskripts in Chrome-Erweiterungen auf globale Variablen zu?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage