background
| Typ | Object |
|---|---|
| Verpflichtend | Nein |
| Manifest-Version | 2 oder höher |
| Beispiel |
json |
Verwenden Sie den background-Schlüssel, um ein oder mehrere Hintergrundskripte, eine Hintergrundseite oder einen Service Worker in Ihre Erweiterung einzubinden.
Hintergrundskripte sind der Ort, um Code zu platzieren, der einen langfristigen Zustand aufrechterhalten oder langfristige Operationen unabhängig von der Lebensdauer bestimmter Webseiten oder Browserfenster ausführen muss.
Hintergrundskripte werden geladen, sobald die Erweiterung geladen ist, und bleiben geladen, bis die Erweiterung deaktiviert oder deinstalliert wird, es sei denn, persistent ist als false angegeben. Sie können in dem Skript alle WebExtension-APIs verwenden, wenn Sie die notwendigen Berechtigungen angefordert haben.
Details finden Sie unter Hintergrundskripte.
Der background-Schlüssel ist ein Objekt, das eine dieser Eigenschaften haben muss (für weitere Informationen darüber, wie diese Eigenschaften unterstützt werden, siehe Browser-Unterstützung):
page |
Wenn Sie spezifischen Inhalt auf der Hintergrundseite benötigen, können Sie eine Seite mit der Eigenschaft
Wenn Sie diese Eigenschaft verwenden, können Sie keine Hintergrundskripte mit |
scripts |
Ein Die Skripte teilen sich den gleichen globalen Kontext Die Skripte werden in der Reihenfolge geladen, in der sie im Array erscheinen.
Wenn Sie
Hinweis: Wenn Sie ein Skript von einem entfernten Ort mit dem |
service_worker |
Geben Sie eine JavaScript-Datei als Service Worker der Erweiterung an. Ein Service Worker ist ein Hintergrundskript, das als Hauptereignis-Handler der Erweiterung fungiert. |
Der background-Schlüssel kann auch diese optionale Eigenschaft enthalten:
persistent |
Ein Wenn weggelassen, ist diese Eigenschaft standardmäßig
|
preferred_environment |
Ein Wenn
Chrome unterstützt nur Service Worker, daher ignoriert es diesen Schlüssel. Wenn weggelassen, führen Firefox und Safari Hintergrundskripte als Dokumente aus. Safari verwendet einen Service Worker Kontext, wenn die Erweiterung |
type |
Ein Bestimmt, ob die in
Wenn weggelassen, ist diese Eigenschaft standardmäßig |
Browser-Unterstützung
Die Unterstützung für die Eigenschaften scripts, page und service_worker variiert zwischen den Browsern wie folgt:
- Chrome:
- unterstützt
background.service_worker. - unterstützt
background.scripts(undbackground.page) nur in Manifest V2 Erweiterungen. - vor Chrome 121 verweigert Chrome das Laden einer Manifest V3 Erweiterung mit vorhandenem
background.scriptsoderbackground.page. Ab Chrome 121 wird deren Vorhandensein in einer Manifest V3 Erweiterung ignoriert.
- unterstützt
- Firefox:
background.service_workerwird nicht unterstützt (siehe Firefox-Bug 1573659).- unterstützt
background.scripts(oderbackground.page), wennservice_workernicht angegeben ist oder die Service Worker Funktion deaktiviert ist. Vor Firefox 120 startete Firefox die Hintergrundseite nicht, wennservice_workervorhanden war (siehe Firefox-Bug 1860304). Ab Firefox 121 startet die Hintergrundseite wie erwartet, unabhängig von der Anwesenheit vonservice_worker.
- Safari:
- unterstützt
background.scripts(oderbackground.page) undbackground.service_worker. - wenn beide angegeben sind, verwendet Safari
background.scripts(oderbackground.page), es sei dennpreferred_environmentist aufservice_workergesetzt. - wenn
preferred_environmentaufservice_workergesetzt ist undbackground.service_workernicht angegeben ist, generiert Safari einen Service Worker vonbackground.scripts, wenn vorhanden.
- unterstützt
Cross-Browser Manifest V3 Hintergrundskripte
Um Browser mit unterschiedlichen Implementierungen für Manifest V3 Hintergrundskripte zu unterstützen, geben Sie sowohl scripts als auch service_worker im background-Schlüssel an. Browser, die Service Worker für Hintergrunddienste unterstützen, verwenden service_worker, während Browser, die Ereignisseiten für diesen Fall verwenden, scripts einsetzen.
Sie müssen preferred_environment für dieses Fallback-Verhalten nicht einschließen. Verwenden Sie preferred_environment nur, wenn Sie möchten, dass Safari oder ein anderer Browser, der mehr als eine Hintergrundumgebung unterstützt, service_worker bevorzugt, wo verfügbar.
Dieses Beispiel zeigt die relevanten Teile eines Manifests, das sowohl scripts als auch service_worker enthält:
{
"name": "Demo of service worker + event page",
"version": "1",
"manifest_version": 3,
"background": {
"scripts": ["background.js"],
"service_worker": "background.js"
}
}
Und, background.js enthält:
browser.runtime.onInstalled.addListener(() => {
browser.tabs.create({ url: "http://example.com/first-run.html" });
});
Mit dieser background-Konfiguration passiert Folgendes:
- in Chrome wird die
service_worker-Eigenschaft verwendet und ein Service Worker gestartet, da Chrome in einer Manifest V3 Erweiterung nur Service Worker für Hintergrundskripte unterstützt. - in Firefox wird die
scripts-Eigenschaft verwendet und eine Ereignisseite gestartet, da Firefox nur Skripte für Hintergrundskripte unterstützt. - in Safari wird standardmäßig die
scripts-Eigenschaft verwendet und eine Ereignisseite gestartet.
Beispiele
"background": {
"scripts": ["jquery.js", "my-background.js"]
}
Laden Sie zwei Hintergrundskripte.
"background": {
"page": "my-background.html"
}
Laden Sie eine benutzerdefinierte Hintergrundseite.