windows.getAll()
Ruft Informationen über alle geöffneten Fenster ab und übergibt sie an einen Callback.
Dies ist eine asynchrone Funktion, die ein Promise
zurückgibt.
Syntax
let gettingAll = browser.windows.getAll(
getInfo // optional object
)
Parameter
getInfo
Optional-
object
. Dies steuert, welchewindows.Window
Objekte abgerufen werden.populate
Optional-
boolean
. Standardmäßigfalse
. Wenn auftrue
gesetzt, enthält jedeswindows.Window
Objekt einetabs
Eigenschaft, die eine Liste vontabs.Tab
Objekten repräsentiert, die die Tabs in diesem Fenster darstellen. DieTab
Objekte enthalten die Eigenschaftenurl
,title
undfavIconUrl
nur, wenn die Manifestdatei der Erweiterung die Berechtigung"tabs"
oder Host-Berechtigungen enthält, die mit der URL des Tabs übereinstimmen. windowTypes
Optional-
Ein
array
vonwindows.WindowType
Objekten. Wenn gesetzt, werden die zurückgegebenenwindows.Window
Objekte basierend auf ihrem Typ gefiltert. Wenn nicht gesetzt, ist der Standardfilter auf['normal', 'panel', 'popup']
gesetzt, wobei'panel'
Fenstertypen auf die eigenen Fenster der Erweiterung beschränkt sind.
Rückgabewert
Ein Promise
, das mit einem Array von windows.Window
Objekten erfüllt wird, die alle Fenster repräsentieren, die den angegebenen Kriterien entsprechen. Wenn ein Fehler auftritt, wird das Promise mit einer Fehlermeldung abgelehnt.
Browser-Kompatibilität
BCD tables only load in the browser
Beispiele
Protokollieren Sie die URLs für die Tabs über alle "normalen" Browserfenster. Beachten Sie, dass Sie die "tabs" Berechtigung oder passende Host-Berechtigungen benötigen, um auf Tab-URLs zuzugreifen.
function logTabsForWindows(windowInfoArray) {
for (const windowInfo of windowInfoArray) {
console.log(`Window: ${windowInfo.id}`);
console.log(windowInfo.tabs.map((tab) => tab.url));
}
}
function onError(error) {
console.error(`Error: ${error}`);
}
browser.browserAction.onClicked.addListener((tab) => {
browser.windows
.getAll({
populate: true,
windowTypes: ["normal"],
})
.then(logTabsForWindows, onError);
});
Beispielerweiterungen
Hinweis:
Diese API basiert auf der chrome.windows
API von Chromium. Diese Dokumentation ist von windows.json
im Chromium-Code abgeleitet.