Beschrijving
De naamruimte chrome.events
bevat algemene typen die worden gebruikt door API's die gebeurtenissen verzenden om u op de hoogte te stellen wanneer er iets interessants gebeurt.
Concepten en gebruik
Een Event
is een object waarmee u op de hoogte kunt worden gesteld wanneer er iets interessants gebeurt. Hier is een voorbeeld van het gebruik van de gebeurtenis chrome.alarms.onAlarm
om een melding te krijgen wanneer een alarm is verstreken:
chrome.alarms.onAlarm.addListener((alarm) => {
appendToLog(`alarms.onAlarm -- name: ${alarm.name}, scheduledTime: ${alarm.scheduledTime}`);
});
Zoals het voorbeeld laat zien, registreert u zich voor melding met addListener()
. Het argument voor addListener()
is altijd een functie die u definieert om de gebeurtenis af te handelen, maar de parameters voor de functie zijn afhankelijk van de gebeurtenis die u afhandelt. Als u de documentatie voor alarms.onAlarm
bekijkt, ziet u dat de functie één enkele parameter heeft: een alarms.Alarm
-object dat details bevat over het verstreken alarm.
Voorbeeld-API's die gebruikmaken van gebeurtenissen: alarms , i18n , Identity , runtime . De meeste Chrome-API's doen dat.
Declaratieve gebeurtenishandlers
De declaratieve gebeurtenishandlers bieden een middel om regels te definiëren die bestaan uit declaratieve voorwaarden en acties. De omstandigheden worden geëvalueerd in de browser in plaats van in de JavaScript-engine, waardoor de roundtrip-latency wordt verminderd en een zeer hoge efficiëntie mogelijk is.
Declaratieve gebeurtenishandlers worden bijvoorbeeld gebruikt in de Declarative Content API . Deze pagina beschrijft de onderliggende concepten van alle declaratieve gebeurtenishandlers.
Regels
De eenvoudigst mogelijke regel bestaat uit een of meer voorwaarden en een of meer acties:
const rule = {
conditions: [ /* my conditions */ ],
actions: [ /* my actions */ ]
};
Als aan één van de voorwaarden is voldaan, worden alle acties uitgevoerd.
Naast voorwaarden en acties kunt u elke regel een ID geven, wat het ongedaan maken van eerder geregistreerde regels vereenvoudigt, en een prioriteit om prioriteit tussen regels te definiëren. Er wordt alleen rekening gehouden met prioriteiten als regels met elkaar in strijd zijn of in een specifieke volgorde moeten worden uitgevoerd. Acties worden uitgevoerd in aflopende volgorde van de prioriteit van hun regels.
const rule = {
id: "my rule", // optional, will be generated if not set.
priority: 100, // optional, defaults to 100.
conditions: [ /* my conditions */ ],
actions: [ /* my actions */ ]
};
Gebeurtenisobjecten
Gebeurtenisobjecten kunnen regels ondersteunen. Deze gebeurtenisobjecten roepen geen callback-functie aan wanneer er gebeurtenissen plaatsvinden, maar testen of een geregistreerde regel aan ten minste één voorwaarde voldoet en voeren de acties uit die aan deze regel zijn gekoppeld. Gebeurtenisobjecten die de declaratieve API ondersteunen, hebben drie relevante methoden: events.Event.addRules()
, events.Event.removeRules()
en events.Event.getRules()
.
Regels toevoegen
Om regels toe te voegen, roept u de functie addRules()
van het gebeurtenisobject op. Het heeft een array van regelinstanties nodig als eerste parameter en een callback-functie die na voltooiing wordt aangeroepen.
const rule_list = [rule1, rule2, ...];
addRules(rule_list, (details) => {...});
Als de regels met succes zijn ingevoegd, bevat de parameter details
een array van ingevoegde regels die in dezelfde volgorde verschijnen als in de doorgegeven rule_list
waar de optionele parameters id
en priority
zijn gevuld met de gegenereerde waarden. Als een regel ongeldig is, bijvoorbeeld omdat deze een ongeldige voorwaarde of actie bevat, wordt geen van de regels toegevoegd en wordt de variabele runtime.lastError ingesteld wanneer de callback-functie wordt aangeroepen. Elke regel in rule_list
moet een unieke ID bevatten die nog niet door een andere regel wordt gebruikt, of een lege ID.
Regels verwijderen
Om regels te verwijderen, roept u de functie removeRules()
op. Het accepteert een optionele reeks regel-ID's als eerste parameter en een callback-functie als tweede parameter.
const rule_ids = ["id1", "id2", ...];
removeRules(rule_ids, () => {...});
Als rule_ids
een array van identifiers is, worden alle regels met identifiers in de array verwijderd. Als rule_ids
een identificatie vermeldt die onbekend is, wordt deze identificatie stilzwijgend genegeerd. Als rule_ids
undefined
is, worden alle geregistreerde regels van deze extensie verwijderd. De callback()
functie wordt aangeroepen toen de regels werden verwijderd.
Regels ophalen
Om een lijst met geregistreerde regels op te halen, roept u de functie getRules()
aan. Het accepteert een optionele reeks regel-ID's met dezelfde semantiek als removeRules()
en een callback-functie.
const rule_ids = ["id1", "id2", ...];
getRules(rule_ids, (details) => {...});
De parameter details
die wordt doorgegeven aan de functie callback()
verwijst naar een reeks regels inclusief ingevulde optionele parameters.
Prestatie
Om maximale prestaties te bereiken, moet u de volgende richtlijnen in gedachten houden.
Regels bulksgewijs registreren en afmelden. Na elke registratie of uitschrijving moet Chrome de interne gegevensstructuren updaten. Deze update is een dure operatie.
const rule1 = {...}; const rule2 = {...}; chrome.declarativeWebRequest.onRequest.addRules([rule1]); chrome.declarativeWebRequest.onRequest.addRules([rule2]);
const rule1 = {...}; const rule2 = {...}; chrome.declarativeWebRequest.onRequest.addRules([rule1, rule2]);
Geef de voorkeur aan het matchen van subtekenreeksen boven reguliere expressies in een events.UrlFilter . Matchen op basis van substrings is extreem snel.
const match = new chrome.declarativeWebRequest.RequestMatcher({ url: {urlMatches: "example.com/[^?]*foo" } });
const match = new chrome.declarativeWebRequest.RequestMatcher({ url: {hostSuffix: "example.com", pathContains: "foo"} });
Als er veel regels zijn die dezelfde acties delen, voegt u de regels samen tot één regel. Regels activeren hun acties zodra aan een enkele voorwaarde is voldaan. Dit versnelt het matchen en vermindert het geheugengebruik voor dubbele actiesets.
const condition1 = new chrome.declarativeWebRequest.RequestMatcher({ url: { hostSuffix: 'example.com' } }); const condition2 = new chrome.declarativeWebRequest.RequestMatcher({ url: { hostSuffix: 'foobar.com' } }); const rule1 = { conditions: [condition1], actions: [new chrome.declarativeWebRequest.CancelRequest()] }; const rule2 = { conditions: [condition2], actions: [new chrome.declarativeWebRequest.CancelRequest()] }; chrome.declarativeWebRequest.onRequest.addRules([rule1, rule2]);
const condition1 = new chrome.declarativeWebRequest.RequestMatcher({ url: { hostSuffix: 'example.com' } }); const condition2 = new chrome.declarativeWebRequest.RequestMatcher({ url: { hostSuffix: 'foobar.com' } }); const rule = { conditions: [condition1, condition2], actions: [new chrome.declarativeWebRequest.CancelRequest()] }; chrome.declarativeWebRequest.onRequest.addRules([rule]);
Gefilterde evenementen
Gefilterde gebeurtenissen zijn een mechanisme waarmee luisteraars een subset van gebeurtenissen kunnen specificeren waarin zij geïnteresseerd zijn. Een luisteraar die een filter gebruikt, wordt niet aangeroepen voor gebeurtenissen die het filter niet passeren, waardoor de luistercode declaratiever en efficiënter wordt. . Een servicemedewerker hoeft niet wakker te worden gemaakt om gebeurtenissen af te handelen die hem niet interesseren.
Gefilterde gebeurtenissen zijn bedoeld om een overgang van handmatige filtercode mogelijk te maken.
chrome.webNavigation.onCommitted.addListener((event) => { if (hasHostSuffix(event.url, 'google.com') || hasHostSuffix(event.url, 'google.com.au')) { // ... } });
chrome.webNavigation.onCommitted.addListener((event) => { // ... }, {url: [{hostSuffix: 'google.com'}, {hostSuffix: 'google.com.au'}]});
Gebeurtenissen ondersteunen specifieke filters die betekenisvol zijn voor die gebeurtenis. De lijst met filters die een gebeurtenis ondersteunt, wordt vermeld in de documentatie voor die gebeurtenis in de sectie 'filters'.
Bij het matchen van URL's (zoals in het bovenstaande voorbeeld) ondersteunen gebeurtenisfilters dezelfde mogelijkheden voor URL-matching als die kunnen worden uitgedrukt met events.UrlFilter
, behalve voor het matchen van schema's en poorten.
Soorten
Event
Een object waarmee luisteraars voor een Chrome-gebeurtenis kunnen worden toegevoegd en verwijderd.
Eigenschappen
- addListener
leegte
Registreert een terugbelactie van een gebeurtenislistener naar een gebeurtenis.
De
addListener
functie ziet er als volgt uit:(callback: H) => {...}
- terugbellen
H
Wordt gebeld wanneer er een gebeurtenis plaatsvindt. De parameters van deze functie zijn afhankelijk van het type gebeurtenis.
- regels toevoegen
leegte
Registreert regels voor het afhandelen van gebeurtenissen.
De
addRules
functie ziet er als volgt uit:(rules: Rule<anyany>[], callback?: function) => {...}
- regels
Regel <anyany>[]
Regels om te registreren. Deze vervangen geen eerder geregistreerde regels.
- terugbellen
functie optioneel
De
callback
parameter ziet er als volgt uit:(rules: Rule<anyany>[]) => void
- regels
Regel <anyany>[]
Regels die zijn geregistreerd, de optionele parameters zijn gevuld met waarden.
- ontvangRegels
leegte
Retourneert momenteel geregistreerde regels.
De
getRules
functie ziet er als volgt uit:(ruleIdentifiers?: string[], callback: function) => {...}
- ruleIdentifiers
tekenreeks[] optioneel
Als een array wordt doorgegeven, worden alleen regels met ID's in deze array geretourneerd.
- terugbellen
functie
De
callback
parameter ziet er als volgt uit:(rules: Rule<anyany>[]) => void
- regels
Regel <anyany>[]
Regels die zijn geregistreerd, de optionele parameters zijn gevuld met waarden.
- heeftListener
leegte
De
hasListener
functie ziet er als volgt uit:(callback: H) => {...}
- terugbellen
H
Luisteraar wiens registratiestatus wordt getest.
- retourneert
Booleaans
Waar als callback is geregistreerd voor de gebeurtenis.
- heeft luisteraars
leegte
De
hasListeners
functie ziet er als volgt uit:() => {...}
- retourneert
Booleaans
Waar als er gebeurtenislisteners bij de gebeurtenis zijn geregistreerd.
- verwijderListener
leegte
Maakt de registratie van een terugbellen van een gebeurtenislistener bij een gebeurtenis ongedaan.
De
removeListener
functie ziet er als volgt uit:(callback: H) => {...}
- terugbellen
H
Luisteraar die niet is geregistreerd.
- verwijderRegels
leegte
Maakt de registratie van momenteel geregistreerde regels ongedaan.
De
removeRules
functie ziet er als volgt uit:(ruleIdentifiers?: string[], callback?: function) => {...}
- ruleIdentifiers
tekenreeks[] optioneel
Als een array wordt doorgegeven, worden alleen regels met ID's in deze array niet meer geregistreerd.
- terugbellen
functie optioneel
De
callback
parameter ziet er als volgt uit:() => void
Rule
Beschrijving van een declaratieve regel voor het afhandelen van gebeurtenissen.
Eigenschappen
- acties
elk[]
Lijst met acties die worden geactiveerd als aan een van de voorwaarden is voldaan.
- voorwaarden
elk[]
Lijst met voorwaarden die de acties kunnen activeren.
- Identiteitskaart
tekenreeks optioneel
Optionele ID waarmee naar deze regel kan worden verwezen.
- prioriteit
nummer optioneel
Optionele prioriteit van deze regel. Standaard ingesteld op 100.
- labels
tekenreeks[] optioneel
Tags kunnen worden gebruikt om regels te annoteren en bewerkingen uit te voeren op sets regels.
UrlFilter
Filtert URL's op verschillende criteria. Zie gebeurtenisfiltering . Alle criteria zijn hoofdlettergevoelig.
Eigenschappen
- cidrBlokken
tekenreeks[] optioneel
Chroom 123+Komt overeen als het hostgedeelte van de URL een IP-adres is en zich bevindt in een van de CIDR-blokken die in de array zijn opgegeven.
- hostBevat
tekenreeks optioneel
Komt overeen als de hostnaam van de URL een opgegeven tekenreeks bevat. Om te testen of een hostnaamcomponent het voorvoegsel 'foo' heeft, gebruikt u hostContains: '.foo'. Dit komt overeen met 'www.foobar.com' en 'foo.com', omdat er een impliciete punt aan het begin van de hostnaam is toegevoegd. Op dezelfde manier kan hostContains worden gebruikt om te matchen met het componentachtervoegsel ('foo.') en om exact te matchen met componenten ('.foo.'). Achtervoegsels en exacte overeenkomsten voor de laatste componenten moeten afzonderlijk worden uitgevoerd met behulp van hostSuffix, omdat er geen impliciete punt aan het einde van de hostnaam wordt toegevoegd.
- gastheerGelijk
tekenreeks optioneel
Komt overeen als de hostnaam van de URL gelijk is aan een opgegeven tekenreeks.
- hostvoorvoegsel
tekenreeks optioneel
Komt overeen als de hostnaam van de URL begint met een opgegeven tekenreeks.
- hostachtervoegsel
tekenreeks optioneel
Komt overeen als de hostnaam van de URL eindigt met een opgegeven tekenreeks.
- originAndPathMatches
tekenreeks optioneel
Komt overeen als de URL zonder querysegment en fragment-ID overeenkomt met een opgegeven reguliere expressie. Poortnummers worden uit de URL verwijderd als ze overeenkomen met het standaardpoortnummer. De reguliere expressies gebruiken de RE2-syntaxis .
- padBevat
tekenreeks optioneel
Komt overeen als het padsegment van de URL een opgegeven tekenreeks bevat.
- padGelijk aan
tekenreeks optioneel
Komt overeen als het padsegment van de URL gelijk is aan een opgegeven tekenreeks.
- padVoorvoegsel
tekenreeks optioneel
Komt overeen als het padsegment van de URL begint met een opgegeven tekenreeks.
- padAchtervoegsel
tekenreeks optioneel
Komt overeen als het padsegment van de URL eindigt met een opgegeven tekenreeks.
- havens
(nummer | nummer[])[] optioneel
Komt overeen als de poort van de URL in een van de opgegeven poortlijsten staat.
[80, 443, [1000, 1200]]
komt bijvoorbeeld overeen met alle verzoeken op poort 80, 443 en in het bereik 1000-1200. - vraagBevat
tekenreeks optioneel
Komt overeen als het zoeksegment van de URL een opgegeven tekenreeks bevat.
- vraagGelijk aan
tekenreeks optioneel
Komt overeen als het zoeksegment van de URL gelijk is aan een opgegeven tekenreeks.
- queryPrefix
tekenreeks optioneel
Komt overeen als het zoeksegment van de URL begint met een opgegeven tekenreeks.
- queryAchtervoegsel
tekenreeks optioneel
Komt overeen als het zoeksegment van de URL eindigt met een opgegeven tekenreeks.
- schema's
tekenreeks[] optioneel
Komt overeen als het schema van de URL gelijk is aan een van de schema's die in de array zijn opgegeven.
- urlBevat
tekenreeks optioneel
Komt overeen als de URL (zonder fragment-ID) een opgegeven tekenreeks bevat. Poortnummers worden uit de URL verwijderd als ze overeenkomen met het standaardpoortnummer.
- urlGelijk aan
tekenreeks optioneel
Komt overeen als de URL (zonder fragment-ID) gelijk is aan een opgegeven tekenreeks. Poortnummers worden uit de URL verwijderd als ze overeenkomen met het standaardpoortnummer.
- urlmatches
tekenreeks optioneel
Komt overeen als de URL (zonder fragment-ID) overeenkomt met een opgegeven reguliere expressie. Poortnummers worden uit de URL verwijderd als ze overeenkomen met het standaardpoortnummer. De reguliere expressies gebruiken de RE2-syntaxis .
- urlVoorvoegsel
tekenreeks optioneel
Komt overeen als de URL (zonder fragment-ID) begint met een opgegeven tekenreeks. Poortnummers worden uit de URL verwijderd als ze overeenkomen met het standaardpoortnummer.
- urlAchtervoegsel
tekenreeks optioneel
Komt overeen als de URL (zonder fragment-ID) eindigt met een opgegeven tekenreeks. Poortnummers worden uit de URL verwijderd als ze overeenkomen met het standaardpoortnummer.