Description
Utilisez l'API chrome.history
pour interagir avec l'historique des pages visitées du navigateur. Vous pouvez ajouter, supprimer et interroger des URL dans l'historique du navigateur. Pour remplacer la page de l'historique par votre propre version, consultez Remplacer des pages.
Autorisations
history
Fichier manifeste
Vous devez déclarer l'autorisation "history" dans le fichier manifeste de l'extension pour utiliser l'API History. Exemple :
{
"name": "My extension",
...
"permissions": [
"history"
],
...
}
Types de transitions
L'API History utilise un type de transition pour décrire la façon dont le navigateur a accédé à une URL spécifique lors d'une visite donnée. Par exemple, si un utilisateur accède à une page en cliquant sur un lien sur une autre page, le type de transition est "link".
Le tableau suivant décrit chaque type de transition.
Type de transition | Description |
---|---|
"link" | L'utilisateur a accédé à cette page en cliquant sur un lien sur une autre page. |
"typed" | L'utilisateur a accédé à cette page en saisissant l'URL dans la barre d'adresse. Également utilisé pour d'autres actions de navigation explicites. Consultez également generated, qui est utilisé lorsque l'utilisateur a sélectionné un choix qui ne ressemblait pas du tout à une URL. |
"auto_bookmark" | L'utilisateur a accédé à cette page via une suggestion dans l'UI, par exemple via un élément de menu. |
"auto_subframe" | Navigation dans les sous-frames. Il s'agit de tout contenu chargé automatiquement dans un frame autre que celui de premier niveau. Par exemple, si une page se compose de plusieurs frames contenant des annonces, les URL de ces annonces ont ce type de transition. Il est possible que l'utilisateur ne se rende même pas compte que le contenu de ces pages se trouve dans un frame distinct et qu'il ne se soucie donc pas de l'URL (voir aussi manual_subframe). |
"manual_subframe" | Pour les navigations de sous-frame explicitement demandées par l'utilisateur et qui génèrent de nouvelles entrées de navigation dans la liste "Précédent/Suivant". Un frame demandé explicitement est probablement plus important qu'un frame chargé automatiquement, car l'utilisateur se soucie probablement du fait que le frame demandé a été chargé. |
"generated" | L'utilisateur a accédé à cette page en saisissant une entrée qui ne ressemblait pas à une URL dans la barre d'adresse, puis en la sélectionnant. Par exemple, une correspondance peut avoir l'URL d'une page de résultats de recherche Google, mais elle peut apparaître à l'utilisateur sous la forme "Rechercher sur Google : …". Ces correspondances ne sont pas tout à fait identiques aux navigations saisies, car l'utilisateur n'a pas saisi ni vu l'URL de destination. Voir aussi mot clé. |
"auto_toplevel" | La page a été spécifiée dans la ligne de commande ou est la page de démarrage. |
"form_submit" | L'utilisateur a rempli les valeurs d'un formulaire et l'a envoyé. Notez que dans certaines situations (par exemple, lorsqu'un formulaire utilise un script pour envoyer du contenu), l'envoi d'un formulaire n'entraîne pas ce type de transition. |
"reload" | L'utilisateur a actualisé la page en cliquant sur le bouton d'actualisation ou en appuyant sur Entrée dans la barre d'adresse. La restauration de session et la réouverture d'un onglet fermé utilisent également ce type de transition. |
"mot clé" | L'URL a été générée à partir d'un mot clé remplaçable autre que le moteur de recherche par défaut. Voir aussi keyword_generated. |
"keyword_generated" | Correspond à une visite générée pour un mot clé. Voir aussi mot clé. |
Exemples
Pour essayer cette API, installez l'exemple d'API History à partir du dépôt chrome-extension-samples.
Types
HistoryItem
Objet encapsulant un résultat d'une requête d'historique.
Propriétés
-
id
chaîne
Identifiant unique de l'élément.
-
lastVisitTime
number facultatif
Heure à laquelle cette page a été chargée pour la dernière fois, exprimée en millisecondes depuis l'epoch.
-
titre
chaîne facultative
Titre de la page lors de son dernier chargement.
-
typedCount
number facultatif
Nombre de fois où l'utilisateur a accédé à cette page en saisissant l'adresse.
-
url
chaîne facultative
URL vers laquelle un utilisateur a accédé.
-
visitCount
number facultatif
Nombre de fois où l'utilisateur a accédé à cette page.
TransitionType
Le type de transition pour cette visite à partir de son site référent.
Énumération
link
L'utilisateur est arrivé sur cette page en cliquant sur un lien sur une autre page.
"typed"
L'utilisateur est arrivé sur cette page en saisissant l'URL dans la barre d'adresse. Elle est également utilisée pour d'autres actions de navigation explicites.
"auto_bookmark"
L'utilisateur est arrivé sur cette page via une suggestion dans l'UI, par exemple via un élément de menu.
"auto_subframe"
L'utilisateur est arrivé sur cette page via une navigation dans un sous-frame qu'il n'a pas demandée, par exemple via une annonce se chargeant dans un frame sur la page précédente. Elles ne génèrent pas toujours de nouvelles entrées de navigation dans les menus "Précédent" et "Suivant".
"manual_subframe"
L'utilisateur est arrivé sur cette page en sélectionnant un élément dans un sous-frame.
"generated"
L'utilisateur est arrivé sur cette page en saisissant une entrée dans la barre d'adresse et en sélectionnant une entrée qui ne ressemblait pas à une URL, comme une suggestion de recherche Google. Par exemple, une correspondance peut avoir l'URL d'une page de résultats de recherche Google, mais elle peut apparaître à l'utilisateur sous la forme "Rechercher sur Google : …". Ces correspondances sont différentes des navigations saisies, car l'utilisateur n'a pas saisi ni vu l'URL de destination. Elles sont également liées aux navigations au clavier.
"auto_toplevel"
La page a été spécifiée dans la ligne de commande ou est la page de démarrage.
"form_submit"
L'utilisateur est arrivé sur cette page en remplissant les valeurs d'un formulaire et en l'envoyant. Tous les envois de formulaires n'utilisent pas ce type de transition.
"reload"
L'utilisateur a actualisé la page en cliquant sur le bouton d'actualisation ou en appuyant sur Entrée dans la barre d'adresse. La restauration de session et la réouverture d'un onglet fermé utilisent également ce type de transition.
"keyword"
L'URL de cette page a été générée à partir d'un mot clé remplaçable autre que le moteur de recherche par défaut.
keyword_generated
Correspond à une visite générée pour un mot clé.
UrlDetails
Propriétés
-
url
chaîne
URL de l'opération. Il doit être au format renvoyé par un appel à
history.search()
.
VisitItem
Objet encapsulant une visite d'URL.
Propriétés
-
id
chaîne
Identifiant unique du
history.HistoryItem
correspondant. -
isLocal
booléen
Chrome 115 et versions ultérieures"True" si la visite a commencé sur cet appareil. "False" si elle a été synchronisée depuis un autre appareil.
-
referringVisitId
chaîne
ID de visite du site de provenance.
-
transition
Le type de transition pour cette visite à partir de son site référent.
-
visitId
chaîne
Identifiant unique de cette visite.
-
visitTime
number facultatif
Heure à laquelle cette visite a eu lieu, représentée en millisecondes depuis l'epoch.
Méthodes
addUrl()
chrome.history.addUrl(
details: UrlDetails,
callback?: function,
): Promise<void>
Ajoute une URL à l'historique à l'heure actuelle avec un type de transition "link".
Paramètres
-
détails
-
callback
function facultatif
Le paramètre
callback
se présente comme suit :() => void
Renvoie
-
Promise<void>
Chrome 96 et versions ultérieuresLes promesses ne sont compatibles qu'avec Manifest V3 et les versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
deleteAll()
chrome.history.deleteAll(
callback?: function,
): Promise<void>
Supprime tous les éléments de l'historique.
Paramètres
-
callback
function facultatif
Le paramètre
callback
se présente comme suit :() => void
Renvoie
-
Promise<void>
Chrome 96 et versions ultérieuresLes promesses ne sont compatibles qu'avec Manifest V3 et les versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
deleteRange()
chrome.history.deleteRange(
range: object,
callback?: function,
): Promise<void>
Supprime de l'historique tous les éléments compris dans la plage de dates spécifiée. Les pages ne seront supprimées de l'historique que si toutes les visites se trouvent dans la plage.
Paramètres
-
niveaux
objet
-
endTime
Total
Éléments ajoutés à l'historique avant cette date, représentée en millisecondes depuis l'époque.
-
startTime
Total
Éléments ajoutés à l'historique après cette date, représentée en millisecondes depuis l'époque.
-
-
callback
function facultatif
Le paramètre
callback
se présente comme suit :() => void
Renvoie
-
Promise<void>
Chrome 96 et versions ultérieuresLes promesses ne sont compatibles qu'avec Manifest V3 et les versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
deleteUrl()
chrome.history.deleteUrl(
details: UrlDetails,
callback?: function,
): Promise<void>
Supprime toutes les occurrences de l'URL donnée de l'historique.
Paramètres
-
détails
-
callback
function facultatif
Le paramètre
callback
se présente comme suit :() => void
Renvoie
-
Promise<void>
Chrome 96 et versions ultérieuresLes promesses ne sont compatibles qu'avec Manifest V3 et les versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
getVisits()
chrome.history.getVisits(
details: UrlDetails,
callback?: function,
): Promise<VisitItem[]>
Récupère des informations sur les visites d'une URL.
Paramètres
-
détails
-
callback
function facultatif
Le paramètre
callback
se présente comme suit :(results: VisitItem[]) => void
-
résultats
-
Renvoie
-
Promise<VisitItem[]>
Chrome 96 et versions ultérieuresLes promesses ne sont compatibles qu'avec Manifest V3 et les versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
search()
chrome.history.search(
query: object,
callback?: function,
): Promise<HistoryItem[]>
Recherche dans l'historique la dernière heure de visite de chaque page correspondant à la requête.
Paramètres
-
requête
objet
-
endTime
number facultatif
Limitez les résultats à ceux visités avant cette date, représentée en millisecondes depuis l'époque.
-
maxResults
number facultatif
Nombre maximal de résultats à récupérer. La valeur par défaut est 100.
-
startTime
number facultatif
Limitez les résultats à ceux visités après cette date, représentée en millisecondes depuis l'époque. Si la propriété n'est pas spécifiée, la valeur par défaut est de 24 heures.
-
texte
chaîne
Requête en texte libre envoyée au service d'historique. Laissez ce champ vide pour récupérer toutes les pages.
-
-
callback
function facultatif
Le paramètre
callback
se présente comme suit :(results: HistoryItem[]) => void
-
résultats
-
Renvoie
-
Promise<HistoryItem[]>
Chrome 96 et versions ultérieuresLes promesses ne sont compatibles qu'avec Manifest V3 et les versions ultérieures. Les autres plates-formes doivent utiliser des rappels.
Événements
onVisited
chrome.history.onVisited.addListener(
callback: function,
)
Déclenché lorsqu'une URL est visitée, en fournissant les données HistoryItem
pour cette URL. Cet événement se déclenche avant le chargement de la page.
Paramètres
-
callback
fonction
Le paramètre
callback
se présente comme suit :(result: HistoryItem) => void
-
résultat
-
onVisitRemoved
chrome.history.onVisitRemoved.addListener(
callback: function,
)
Déclenché lorsqu'une ou plusieurs URL sont supprimées de l'historique. Une fois toutes les visites supprimées, l'URL est supprimée de l'historique.
Paramètres
-
callback
fonction
Le paramètre
callback
se présente comme suit :(removed: object) => void
-
supprimé
objet
-
allHistory
booléen
"True" si tout l'historique a été supprimé. Si la valeur est "true", les URL seront vides.
-
URL
string[] facultatif
-
-