Descrizione
Utilizza l'API chrome.devtools.inspectedWindow per interagire con la finestra esaminata: ottieni l'ID scheda per la pagina esaminata, valuta il codice nel contesto della finestra esaminata, ricarica la pagina o ottieni l'elenco delle risorse all'interno della pagina.
Manifest
Utilizza chrome.devtools.inspectedWindow per interagire con la finestra esaminata: ottieni l'ID scheda per
la pagina esaminata, valuta il codice nel contesto della finestra esaminata, ricarica la pagina o ottieni
l'elenco delle risorse all'interno della pagina.
Per un'introduzione generale all'utilizzo delle API DevTools, consulta il Riepilogo delle API DevTools.
Panoramica
La proprietà tabId fornisce l'identificatore della scheda che puoi utilizzare con le chiamate API chrome.tabs.*. Tuttavia, tieni presente che l'API chrome.tabs.* non è esposta alle pagine di estensione degli strumenti per sviluppatori
per motivi di sicurezza. Dovrai passare l'ID scheda alla pagina
in background e richiamare le funzioni dell'API chrome.tabs.* da lì.
Il metodo reload può essere utilizzato per ricaricare la pagina ispezionata. Inoltre, il chiamante può specificare
un override per la stringa user agent, uno script che verrà inserito all'inizio del caricamento della pagina o un'
opzione per forzare il ricaricamento delle risorse memorizzate nella cache.
Utilizza la chiamata getResources e l'evento onResourceContent per ottenere l'elenco delle risorse
(documenti, fogli di stile, script, immagini e così via) all'interno della pagina esaminata. I metodi getContent e
setContent della classe Resource insieme all'evento onResourceContentCommitted possono
essere utilizzati per supportare la modifica dei contenuti delle risorse, ad esempio da parte di un editor esterno.
Esecuzione del codice nella finestra ispezionata
Il metodo eval consente alle estensioni di eseguire codice JavaScript nel contesto della pagina ispezionata. Questo metodo è efficace se utilizzato nel contesto giusto e pericoloso se utilizzato
in modo inappropriato. Utilizza il metodo tabs.executeScript, a meno che tu non abbia bisogno della funzionalità specifica fornita dal metodo eval.
Ecco le principali differenze tra i metodi eval e tabs.executeScript:
- Il metodo
evalnon utilizza un mondo isolato per il codice in fase di valutazione, pertanto lo stato JavaScript della finestra ispezionata è accessibile al codice. Utilizza questo metodo quando è necessario accedere allo stato JavaScript della pagina esaminata. - Il contesto di esecuzione del codice in fase di valutazione include l'API della console degli strumenti per sviluppatori.
Ad esempio, il codice può utilizzare
inspecte$0. - Il codice valutato può restituire un valore che viene passato al callback dell'estensione. Il valore restituito deve essere un oggetto JSON valido (può contenere solo tipi JavaScript primitivi e riferimenti aciclici ad altri oggetti JSON). Presta particolare attenzione durante l'elaborazione dei dati ricevuti dalla pagina esaminata: il contesto di esecuzione è essenzialmente controllato dalla pagina esaminata; una pagina dannosa può influire sui dati restituiti all'estensione.
Tieni presente che una pagina può includere più contesti di esecuzione JavaScript diversi. Ogni frame ha il proprio contesto, più un contesto aggiuntivo per ogni estensione che esegue script dei contenuti in quel frame.
Per impostazione predefinita, il metodo eval viene eseguito nel contesto del frame principale della pagina esaminata.
Il metodo eval accetta un secondo argomento facoltativo che puoi utilizzare per specificare il contesto in cui
viene valutato il codice. Questo oggetto options può contenere una o più delle seguenti chiavi:
frameURL- Utilizza per specificare un frame diverso da quello principale della pagina ispezionata.
contextSecurityOrigin- Utilizza questa opzione per selezionare un contesto all'interno del frame specificato in base alla sua origine web.
useContentScriptContext- Se è true, esegui lo script nello stesso contesto degli script dei contenuti dell'estensione. (Equivalente a specificare l'origine web dell'estensione come origine di sicurezza del contesto.) Può essere utilizzato per scambiare dati con lo script dei contenuti.
Esempi
Il seguente codice verifica la versione di jQuery utilizzata dalla pagina esaminata:
chrome.devtools.inspectedWindow.eval(
"jQuery.fn.jquery",
function(result, isException) {
if (isException) {
console.log("the page is not using jQuery");
} else {
console.log("The page is using jQuery v" + result);
}
}
);
Per provare questa API, installa gli esempi di API devtools dal repository chrome-extension-samples.
Tipi
Resource
Una risorsa all'interno della pagina esaminata, ad esempio un documento, uno script o un'immagine.
Proprietà
-
url
stringa
L'URL della risorsa.
-
getContent
void
PromessaRecupera i contenuti della risorsa.
La funzione
getContentha questo aspetto:(callback?: function) => {...}
-
callback
funzione facoltativa
Il parametro
callbackha il seguente aspetto:(response: object) => void
-
risposta
oggetto
In attesaUn oggetto contenente i contenuti della risorsa e la relativa codifica.
-
contenuti
stringa
Contenuti della risorsa (potenzialmente codificati).
-
codifica
stringa
Vuoto se i contenuti non sono codificati, altrimenti nome della codifica. Al momento è supportato solo base64.
-
-
-
returns
Promise<object>
In attesaUna funzione che riceve i contenuti delle risorse al completamento della richiesta.
Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.
-
-
setContent
void
PromessaImposta i contenuti della risorsa.
La funzione
setContentha questo aspetto:(content: string, commit: boolean, callback?: function) => {...}
-
contenuti
stringa
Nuovi contenuti della risorsa. Al momento sono supportate solo le risorse di tipo testo.
-
commit
booleano
True se l'utente ha terminato la modifica della risorsa e il nuovo contenuto della risorsa deve essere reso persistente; false se si tratta di una modifica secondaria inviata durante la modifica della risorsa da parte dell'utente.
-
callback
funzione facoltativa
Il parametro
callbackha il seguente aspetto:(error?: object) => void
-
errore
oggetto facoltativo
Impostato su undefined se il contenuto della risorsa è stato impostato correttamente; descrive l'errore in caso contrario.
-
-
returns
Promise<object>
In attesaUna funzione chiamata al completamento della richiesta.
Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.
-
Proprietà
tabId
L'ID della scheda in fase di ispezione. Questo ID può essere utilizzato con chrome.tabs.* tramite Google Cloud CLI o tramite l'API Compute Engine.
Tipo
numero
Metodi
eval()
chrome.devtools.inspectedWindow.eval(
expression: string,
options?: object,
callback?: function,
): Promise<object>
Valuta un'espressione JavaScript nel contesto del frame principale della pagina esaminata. L'espressione deve restituire un oggetto conforme a JSON, altrimenti viene generata un'eccezione. La funzione eval può segnalare un errore lato DevTools o un'eccezione JavaScript che si verifica durante la valutazione. In entrambi i casi, il parametro result del callback è undefined. In caso di errore lato DevTools, il parametro isException non è nullo e isError è impostato su true e code su un codice di errore. In caso di errore JavaScript, isException è impostato su true e value è impostato sul valore stringa dell'oggetto generato.
Parametri
-
espressione
stringa
Un'espressione da valutare.
-
opzioni
oggetto facoltativo
Il parametro options può contenere una o più opzioni.
-
frameURL
stringa facoltativa
Se specificata, l'espressione viene valutata sull'iframe il cui URL corrisponde a quello specificato. Per impostazione predefinita, l'espressione viene valutata nel frame superiore della pagina esaminata.
-
scriptExecutionContext
stringa facoltativa
Chrome 107+Valuta l'espressione nel contesto di uno script di contenuti di un'estensione che corrisponde all'origine specificata. Se specificato, scriptExecutionContext sostituisce l'impostazione "true" di useContentScriptContext.
-
useContentScriptContext
booleano facoltativo
Valuta l'espressione nel contesto dello script di contenuti dell'estensione chiamante, a condizione che lo script di contenuti sia già inserito nella pagina esaminata. In caso contrario, l'espressione non viene valutata e il callback viene richiamato con il parametro di eccezione impostato su un oggetto con il campo
isErrorimpostato su true e il campocodeimpostato suE_NOTFOUND.
-
-
callback
funzione facoltativa
Il parametro
callbackha il seguente aspetto:(response: object) => void
-
risposta
oggetto
In attesaIl risultato della valutazione e le informazioni sulle eccezioni.
-
exceptionInfo
oggetto
Un oggetto che fornisce i dettagli se si è verificata un'eccezione durante la valutazione dell'espressione.
-
codice
stringa
Imposta se l'errore si è verificato sul lato DevTools prima che l'espressione venga valutata.
-
descrizione
stringa
Imposta se l'errore si è verificato sul lato DevTools prima che l'espressione venga valutata.
-
dettagli
any[]
Indica se l'errore si è verificato sul lato DevTools prima che l'espressione venga valutata. Contiene l'array dei valori che possono essere sostituiti nella stringa di descrizione per fornire maggiori informazioni sulla causa dell'errore.
-
isError
booleano
Imposta se l'errore si è verificato sul lato DevTools prima che l'espressione venga valutata.
-
isException
booleano
Imposta se il codice valutato genera un'eccezione non gestita.
-
valore
stringa
Imposta se il codice valutato genera un'eccezione non gestita.
-
-
risultato
oggetto
Il risultato della valutazione.
-
-
Resi
-
Promise<object>
In attesaUna funzione chiamata al termine della valutazione.
Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.
getResources()
chrome.devtools.inspectedWindow.getResources(
callback?: function,
): Promise<Resource[]>
Recupera l'elenco delle risorse dalla pagina ispezionata.
Parametri
Resi
-
Promise<Resource[]>
In attesaUna funzione che riceve l'elenco delle risorse al termine della richiesta.
Le promesse sono supportate solo per Manifest V3 e versioni successive, le altre piattaforme devono utilizzare i callback.
reload()
chrome.devtools.inspectedWindow.reload(
reloadOptions?: object,
): void
Ricarica la pagina ispezionata.
Parametri
-
reloadOptions
oggetto facoltativo
-
ignoreCache
booleano facoltativo
Se il valore è true, il caricatore ignorerà la cache per tutte le risorse della pagina esaminate caricate prima dell'attivazione dell'evento
load. L'effetto è simile a quello che si ottiene premendo Ctrl+Maiusc+R nella finestra ispezionata o nella finestra degli Strumenti per sviluppatori. -
injectedScript
stringa facoltativa
Se specificato, lo script verrà inserito in ogni frame della pagina ispezionata immediatamente dopo il caricamento, prima di qualsiasi script del frame. Lo script non verrà inserito dopo i ricaricamenti successivi, ad esempio se l'utente preme Ctrl+R.
-
userAgent
stringa facoltativa
Se specificata, la stringa sostituirà il valore dell'intestazione HTTP
User-Agentinviata durante il caricamento delle risorse della pagina ispezionata. La stringa sostituirà anche il valore della proprietànavigator.userAgentrestituita a tutti gli script in esecuzione nella pagina esaminata.
-
Eventi
onResourceAdded
chrome.devtools.inspectedWindow.onResourceAdded.addListener(
callback: function,
)
Attivato quando viene aggiunta una nuova risorsa alla pagina esaminata.
Parametri
-
callback
funzione
Il parametro
callbackha il seguente aspetto:(resource: Resource) => void
-
risorsa
-
onResourceContentCommitted
chrome.devtools.inspectedWindow.onResourceContentCommitted.addListener(
callback: function,
)
Attivato quando viene eseguito il commit di una nuova revisione della risorsa (ad es. l'utente salva una versione modificata della risorsa negli Strumenti per sviluppatori).