Descrizione
Utilizza l'API chrome.windows per interagire con le finestre del browser. Puoi utilizzare questa API per creare, modificare e riorganizzare le finestre nel browser.
Autorizzazioni
Se richiesto, un windows.Window contiene un array di oggetti tabs.Tab. Devi dichiarare l'autorizzazione "tabs" nel manifest se hai bisogno di accedere alle proprietà url, pendingUrl, title o favIconUrl di tabs.Tab. Ad esempio:
{
"name": "My extension",
...
"permissions": ["tabs"],
...
}
Concetti e utilizzo
La finestra corrente
Molte funzioni nel sistema di estensioni accettano un argomento windowId facoltativo, che per impostazione predefinita è la finestra corrente.
La finestra corrente è la finestra che contiene il codice attualmente in esecuzione. È importante capire che questa finestra può essere diversa da quella in primo piano o attiva.
Ad esempio, supponiamo che un'estensione crei alcune schede o finestre da un singolo file HTML e che il
file HTML contenga una chiamata a tabs.query(). La finestra corrente è quella che contiene la
pagina che ha effettuato la chiamata, indipendentemente dalla finestra in primo piano.
Nel caso dei service worker, il valore della finestra corrente viene ripristinato all'ultima finestra attiva. In alcune circostanze, potrebbe non essere presente alcuna finestra corrente per le pagine in background.
Esempi
Per provare questa API, installa l'esempio di API di Windows dal repository chrome-extension-samples.
Tipi
CreateType
Specifica il tipo di finestra del browser da creare. "panel" è deprecato ed è disponibile solo per le estensioni autorizzate esistenti su ChromeOS.
Enum
"normale"
Specifica la finestra come finestra standard.
"popup"
Specifica la finestra come finestra popup.
"panel"
Specifica la finestra come pannello.
QueryOptions
Proprietà
-
compilare
booleano facoltativo
Se è true, l'oggetto
windows.Windowha una proprietàtabsche contiene un elenco degli oggettitabs.Tab. Gli oggettiTabcontengono solo le proprietàurl,pendingUrl,titleefavIconUrlse il file manifest dell'estensione include l'autorizzazione"tabs". -
windowTypes
WindowType[] facoltativo
Se impostato, il
windows.Windowrestituito viene filtrato in base al tipo. Se non viene impostato, il filtro predefinito è['normal', 'popup'].
Window
Proprietà
-
alwaysOnTop
booleano
Indica se la finestra è impostata per essere sempre in primo piano.
-
Focalizzati
booleano
Indica se la finestra è attualmente attiva.
-
altezza
number optional
L'altezza della finestra, incluso il frame, in pixel. In alcune circostanze, a una finestra potrebbe non essere assegnata una proprietà
height, ad esempio quando si interrogano finestre chiuse dall'APIsessions. -
id
number optional
L'ID della finestra. Gli ID finestra sono univoci all'interno di una sessione del browser. In alcune circostanze, a una finestra potrebbe non essere assegnata una proprietà
ID, ad esempio quando si eseguono query sulle finestre utilizzando l'APIsessions, nel qual caso potrebbe essere presente un ID sessione. -
in incognito
booleano
Indica se la finestra è in modalità di navigazione in incognito.
-
sinistra
number optional
L'offset della finestra dal bordo sinistro dello schermo in pixel. In alcune circostanze, a una finestra potrebbe non essere assegnata una proprietà
left, ad esempio quando si interrogano finestre chiuse dall'APIsessions. -
sessionId
stringa facoltativa
L'ID sessione utilizzato per identificare in modo univoco una finestra, ottenuto dall'API
sessions. -
stato
WindowState facoltativo
Lo stato di questa finestra del browser.
-
schede
Tab[] facoltativo
Array di oggetti
tabs.Tabche rappresentano le schede correnti nella finestra. -
in alto
number optional
L'offset della finestra dal bordo superiore dello schermo in pixel. In alcune circostanze, a una finestra potrebbe non essere assegnata una proprietà
top, ad esempio quando si interrogano finestre chiuse dall'APIsessions. -
tipo
WindowType facoltativo
Il tipo di finestra del browser.
-
larghezza
number optional
La larghezza della finestra, incluso il frame, in pixel. In alcune circostanze, a una finestra potrebbe non essere assegnata una proprietà
width, ad esempio quando si interrogano finestre chiuse dall'APIsessions.
WindowState
Lo stato di questa finestra del browser. In alcune circostanze, a una finestra potrebbe non essere assegnata una proprietà state, ad esempio quando si interrogano finestre chiuse dall'API sessions.
Enum
"normale"
Stato normale della finestra (non ridotta a icona, ingrandita o a schermo intero).
"minimized"
Stato della finestra ridotta a icona.
"maximized"
Stato della finestra massimizzata.
"fullscreen"
Stato della finestra a schermo intero.
WindowType
Il tipo di finestra del browser. In alcune circostanze, a una finestra potrebbe non essere assegnata una proprietà type, ad esempio quando si interrogano finestre chiuse dall'API sessions.
Enum
"normale"
Una normale finestra del browser.
"popup"
Un popup del browser.
"panel"
Obsoleto in questa API. Una finestra in stile pannello delle app Chrome. Le estensioni possono visualizzare solo le proprie finestre del riquadro.
"app"
Deprecato in questa API. Una finestra dell'app Chrome. Le estensioni possono visualizzare solo le finestre della propria app.
"devtools"
Una finestra degli strumenti per sviluppatori.
Proprietà
WINDOW_ID_CURRENT
Il valore windowId che rappresenta la finestra corrente.
Valore
-2
WINDOW_ID_NONE
Il valore windowId che rappresenta l'assenza di una finestra del browser Chrome.
Valore
-1
Metodi
create()
chrome.windows.create(
createData?: object,
): Promise<Window | undefined>
Crea (apre) una nuova finestra del browser con le dimensioni, la posizione o l'URL predefinito facoltativi forniti.
Parametri
-
createData
oggetto facoltativo
-
Focalizzati
booleano facoltativo
Se
true, si apre una finestra attiva. Sefalse, si apre una finestra inattiva. -
altezza
number optional
L'altezza in pixel della nuova finestra, incluso il frame. Se non specificato, il valore predefinito è un'altezza naturale.
-
in incognito
booleano facoltativo
Indica se la nuova finestra deve essere una finestra di navigazione in incognito.
-
sinistra
number optional
Il numero di pixel per posizionare la nuova finestra dal bordo sinistro dello schermo. Se non viene specificato, la nuova finestra viene spostata naturalmente rispetto all'ultima finestra attiva. Questo valore viene ignorato per i riquadri.
-
setSelfAsOpener
booleano facoltativo
Chrome 64+Se
true, la proprietà "window.opener" della finestra appena creata è impostata sul chiamante e si trova nella stessa unità di contesti di navigazione correlati del chiamante. -
stato
WindowState facoltativo
Chrome 44+Lo stato iniziale della finestra. Gli stati
minimized,maximizedefullscreennon possono essere combinati conleft,top,widthoheight. -
tabId
number optional
L'ID della scheda da aggiungere alla nuova finestra.
-
in alto
number optional
Il numero di pixel per posizionare la nuova finestra dal bordo superiore dello schermo. Se non viene specificato, la nuova finestra viene spostata naturalmente rispetto all'ultima finestra attiva. Questo valore viene ignorato per i riquadri.
-
tipo
CreateType facoltativo
Specifica il tipo di finestra del browser da creare.
-
url
stringa | stringa[] facoltativo
Un URL o un array di URL da aprire come schede nella finestra. Gli URL completi devono includere uno schema, ad esempio "http://www.google.com", non "www.google.com". Gli URL non completi vengono considerati relativi all'interno dell'estensione. Per impostazione predefinita, viene visualizzata la pagina Nuova scheda.
-
larghezza
number optional
La larghezza in pixel della nuova finestra, incluso il frame. Se non specificato, il valore predefinito è una larghezza naturale.
-
Resi
-
Promise<Window | undefined>
Chrome 88+
get()
chrome.windows.get(
windowId: number,
queryOptions?: QueryOptions,
): Promise<Window>
Recupera i dettagli di una finestra.
Parametri
-
windowId
numero
-
queryOptions
QueryOptions facoltativo
Chrome 88+
Resi
-
Promise<Window>
Chrome 88+
getAll()
chrome.windows.getAll(
queryOptions?: QueryOptions,
): Promise<Window[]>
Riceve tutte le finestre.
Parametri
-
queryOptions
QueryOptions facoltativo
Chrome 88+
Resi
-
Promise<Window[]>
Chrome 88+
getCurrent()
chrome.windows.getCurrent(
queryOptions?: QueryOptions,
): Promise<Window>
Restituisce la finestra corrente.
Parametri
-
queryOptions
QueryOptions facoltativo
Chrome 88+
Resi
-
Promise<Window>
Chrome 88+
getLastFocused()
chrome.windows.getLastFocused(
queryOptions?: QueryOptions,
): Promise<Window>
Recupera la finestra su cui è stato eseguito l'ultimo focus, in genere la finestra "in primo piano".
Parametri
-
queryOptions
QueryOptions facoltativo
Chrome 88+
Resi
-
Promise<Window>
Chrome 88+
remove()
chrome.windows.remove(
windowId: number,
): Promise<void>
Rimuove (chiude) una finestra e tutte le schede al suo interno.
Parametri
-
windowId
numero
Resi
-
Promise<void>
Chrome 88+
update()
chrome.windows.update(
windowId: number,
updateInfo: object,
): Promise<Window>
Aggiorna le proprietà di una finestra. Specifica solo le proprietà da modificare; le proprietà non specificate rimangono invariate.
Parametri
-
windowId
numero
-
updateInfo
oggetto
-
drawAttention
booleano facoltativo
Se
true, la finestra viene visualizzata in modo da attirare l'attenzione dell'utente, senza modificare la finestra attiva. L'effetto dura finché l'utente non sposta il focus sulla finestra. Questa opzione non ha effetto se la finestra è già attiva. Impostafalseper annullare una precedente richiestadrawAttention. -
Focalizzati
booleano facoltativo
Se
true, porta la finestra in primo piano; non può essere combinato con lo stato "ridotto a icona". Sefalse, porta in primo piano la finestra successiva nell'ordine Z; non può essere combinato con lo stato "schermo intero" o "ingrandita". -
altezza
number optional
L'altezza a cui ridimensionare la finestra in pixel. Questo valore viene ignorato per i riquadri.
-
sinistra
number optional
L'offset dal bordo sinistro dello schermo a cui spostare la finestra in pixel. Questo valore viene ignorato per i riquadri.
-
stato
WindowState facoltativo
Il nuovo stato della finestra. Gli stati "ridotto a icona", "ingrandito" e "a schermo intero" non possono essere combinati con "sinistra", "alto", "larghezza" o "altezza".
-
in alto
number optional
L'offset dal bordo superiore dello schermo a cui spostare la finestra in pixel. Questo valore viene ignorato per i riquadri.
-
larghezza
number optional
La larghezza a cui ridimensionare la finestra in pixel. Questo valore viene ignorato per i riquadri.
-
Resi
-
Promise<Window>
Chrome 88+
Eventi
onBoundsChanged
chrome.windows.onBoundsChanged.addListener(
callback: function,
)
Attivato quando una finestra è stata ridimensionata; questo evento viene inviato solo quando vengono applicati i nuovi limiti e non per le modifiche in corso.
Parametri
-
callback
funzione
Il parametro
callbackha il seguente aspetto:(window: Window) => void
-
finestra
-
onCreated
chrome.windows.onCreated.addListener(
callback: function,
filters?: object,
)
Attivato quando viene creata una finestra.
Parametri
-
callback
funzione
Chrome 46+Il parametro
callbackha il seguente aspetto:(window: Window) => void
-
finestra
Dettagli della finestra creata.
-
-
filtri
oggetto facoltativo
-
windowTypes
Condizioni che il tipo di finestra in fase di creazione deve soddisfare. Per impostazione predefinita, soddisfa
['normal', 'popup'].
-
onFocusChanged
chrome.windows.onFocusChanged.addListener(
callback: function,
filters?: object,
)
Attivato quando cambia la finestra attualmente selezionata. Restituisce chrome.windows.WINDOW_ID_NONE se tutte le finestre di Chrome hanno perso lo stato attivo. Nota:in alcuni gestori di finestre Linux, WINDOW_ID_NONE viene sempre inviato immediatamente prima di passare da una finestra di Chrome all'altra.
Parametri
-
callback
funzione
Chrome 46+Il parametro
callbackha il seguente aspetto:(windowId: number) => void
-
windowId
numero
ID della finestra appena messa a fuoco.
-
-
filtri
oggetto facoltativo
-
windowTypes
Condizioni che il tipo di finestra da rimuovere deve soddisfare. Per impostazione predefinita, soddisfa
['normal', 'popup'].
-
onRemoved
chrome.windows.onRemoved.addListener(
callback: function,
filters?: object,
)
Attivato quando una finestra viene rimossa (chiusa).
Parametri
-
callback
funzione
Chrome 46+Il parametro
callbackha il seguente aspetto:(windowId: number) => void
-
windowId
numero
ID della finestra rimossa.
-
-
filtri
oggetto facoltativo
-
windowTypes
Condizioni che il tipo di finestra da rimuovere deve soddisfare. Per impostazione predefinita, soddisfa
['normal', 'popup'].
-