chrome.devtools.panels

Description

Utilisez l'API chrome.devtools.panels pour intégrer votre extension à l'interface utilisateur de la fenêtre "Outils de développement" : créez vos propres panneaux, accédez aux panneaux existants et ajoutez des barres latérales.

Chaque panneau d'extension et barre latérale s'affiche sous la forme d'une page HTML distincte. Toutes les pages d'extension affichées dans la fenêtre "Outils de développement" ont accès à toutes les parties de l'API chrome.devtools, ainsi qu'à toutes les autres API d'extension.

Vous pouvez utiliser la méthode devtools.panels.setOpenResourceHandler pour installer une fonction de rappel qui gère les demandes des utilisateurs visant à ouvrir une ressource (généralement, un clic sur un lien de ressource dans la fenêtre des outils pour les développeurs). Au maximum, un seul des gestionnaires installés est appelé. Les utilisateurs peuvent spécifier (à l'aide de la boîte de dialogue "Paramètres des outils de développement") le comportement par défaut ou une extension pour gérer les demandes d'ouverture de ressources. Si une extension appelle setOpenResourceHandler() plusieurs fois, seul le dernier gestionnaire est conservé.

Pour obtenir une introduction générale à l'utilisation des API des outils de développement, consultez Résumé des API des outils de développement.

Fichier manifeste

Les clés suivantes doivent être déclarées dans le fichier manifeste pour utiliser cette API.

"devtools_page"

Exemple

Le code suivant ajoute un panneau contenu dans Panel.html, représenté par FontPicker.png dans la barre d'outils des outils de développement et intitulé Sélecteur de police :

chrome.devtools.panels.create("Font Picker",
                              "FontPicker.png",
                              "Panel.html",
                              function(panel) { ... });

Le code suivant ajoute un volet de barre latérale contenu dans Sidebar.html et intitulé Propriétés de la police au panneau "Éléments", puis définit sa hauteur sur 8ex :

chrome.devtools.panels.elements.createSidebarPane("Font Properties",
  function(sidebar) {
    sidebar.setPage("Sidebar.html");
    sidebar.setHeight("8ex");
  }
);

La capture d'écran illustre l'effet de cet exemple sur la fenêtre des outils de développement :

Panneau d'icônes d'extension dans la barre d'outils des outils de développement
Panneau d'icônes d'extension dans la barre d'outils des outils pour les développeurs.

Pour essayer cette API, installez l'exemple d'API des panneaux DevTools à partir du dépôt chrome-extension-samples.

Types

Button

Bouton créé par l'extension.

Propriétés

  • onClicked

    Event<functionvoidvoid>

    Déclenché lorsque l'utilisateur clique sur le bouton.

    La fonction onClicked.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      () => void

  • update

    vide

    Met à jour les attributs du bouton. Si certains arguments sont omis ou définis sur null, les attributs correspondants ne sont pas mis à jour.

    La fonction update se présente comme suit :

    (iconPath?: string, tooltipText?: string, disabled?: boolean) => {...}

    • iconPath

      chaîne facultative

      Chemin d'accès à la nouvelle icône du bouton.

    • tooltipText

      chaîne facultative

      Texte affiché sous forme d'info-bulle lorsque l'utilisateur pointe sur le bouton.

    • désactivé

      booléen facultatif

      Indique si le bouton est désactivé.

ElementsPanel

Représente le panneau "Éléments".

Propriétés

  • onSelectionChanged

    Event<functionvoidvoid>

    Déclenché lorsqu'un objet est sélectionné dans le panneau.

    La fonction onSelectionChanged.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      () => void

  • createSidebarPane

    vide

    Crée un volet dans la barre latérale du panneau.

    La fonction createSidebarPane se présente comme suit :

    (title: string, callback?: function) => {...}

    • titre

      chaîne

      Texte affiché dans la légende de la barre latérale.

    • callback

      function facultatif

      Le paramètre callback se présente comme suit :

      (result: ExtensionSidebarPane) => void

ExtensionPanel

Représente un panneau créé par une extension.

Propriétés

  • onHidden

    Event<functionvoidvoid>

    Déclenché lorsque l'utilisateur quitte le panneau.

    La fonction onHidden.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      () => void

  • onSearch

    Event<functionvoidvoid>

    Déclenché lors d'une action de recherche (démarrage d'une nouvelle recherche, navigation dans les résultats de recherche ou annulation de la recherche).

    La fonction onSearch.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      (action: string, queryString?: string) => void

      • action

        chaîne

      • queryString

        chaîne facultative

  • onShown

    Event<functionvoidvoid>

    Déclenché lorsque l'utilisateur passe au panneau.

    La fonction onShown.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      (window: Window) => void

      • fenêtre

        Fenêtre

  • createStatusBarButton

    vide

    Ajoute un bouton à la barre d'état du panneau.

    La fonction createStatusBarButton se présente comme suit :

    (iconPath: string, tooltipText: string, disabled: boolean) => {...}

    • iconPath

      chaîne

      Chemin d'accès à l'icône du bouton. Le fichier doit contenir une image de 64 x 24 pixels composée de deux icônes de 32 x 24 pixels. L'icône de gauche est utilisée lorsque le bouton est inactif, tandis que celle de droite s'affiche lorsque l'utilisateur appuie sur le bouton.

    • tooltipText

      chaîne

      Texte affiché sous forme d'info-bulle lorsque l'utilisateur pointe sur le bouton.

    • désactivé

      booléen

      Indique si le bouton est désactivé.

  • afficher

    vide

    En attente

    Affiche le panneau en activant l'onglet correspondant.

    La fonction show se présente comme suit :

    () => {...}

ExtensionSidebarPane

Barre latérale créée par l'extension.

Propriétés

  • onHidden

    Event<functionvoidvoid>

    Déclenché lorsque le volet latéral est masqué parce que l'utilisateur a quitté le panneau qui l'héberge.

    La fonction onHidden.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      () => void

  • onShown

    Event<functionvoidvoid>

    Déclenché lorsque le volet de la barre latérale devient visible parce que l'utilisateur est passé au panneau qui l'héberge.

    La fonction onShown.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      (window: Window) => void

      • fenêtre

        Fenêtre

  • setExpression

    vide

    Définit une expression qui est évaluée dans la page inspectée. Le résultat s'affiche dans le volet latéral.

    La fonction setExpression se présente comme suit :

    (expression: string, rootTitle?: string, callback?: function) => {...}

    • expression

      chaîne

      Expression à évaluer dans le contexte de la page inspectée. Les objets JavaScript et les nœuds DOM sont affichés dans une arborescence extensible semblable à celle de la console/de la section "Surveillance".

    • rootTitle

      chaîne facultative

      Titre facultatif pour la racine de l'arborescence d'expression.

    • callback

      function facultatif

      Le paramètre callback se présente comme suit :

      () => void

  • setHeight

    vide

    Définit la hauteur de la barre latérale.

    La fonction setHeight se présente comme suit :

    (height: string) => {...}

    • hauteur

      chaîne

      Spécification de taille de type CSS, telle que '100px' ou '12ex'.

  • setObject

    vide

    Définit un objet conforme à JSON à afficher dans le volet latéral.

    La fonction setObject se présente comme suit :

    (jsonObject: string, rootTitle?: string, callback?: function) => {...}

    • jsonObject

      chaîne

      Objet à afficher dans le contexte de la page inspectée. Évalué dans le contexte de l'appelant (client API).

    • rootTitle

      chaîne facultative

      Titre facultatif pour la racine de l'arborescence d'expression.

    • callback

      function facultatif

      Le paramètre callback se présente comme suit :

      () => void

  • setPage

    vide

    Définit une page HTML à afficher dans le volet latéral.

    La fonction setPage se présente comme suit :

    (path: string) => {...}

    • chemin d'accès

      chaîne

      Chemin d'accès relatif d'une page d'extension à afficher dans la barre latérale.

SourcesPanel

Représente le panneau "Sources".

Propriétés

  • onSelectionChanged

    Event<functionvoidvoid>

    Déclenché lorsqu'un objet est sélectionné dans le panneau.

    La fonction onSelectionChanged.addListener se présente comme suit :

    (callback: function) => {...}

    • callback

      fonction

      Le paramètre callback se présente comme suit :

      () => void

  • createSidebarPane

    vide

    Crée un volet dans la barre latérale du panneau.

    La fonction createSidebarPane se présente comme suit :

    (title: string, callback?: function) => {...}

    • titre

      chaîne

      Texte affiché dans la légende de la barre latérale.

    • callback

      function facultatif

      Le paramètre callback se présente comme suit :

      (result: ExtensionSidebarPane) => void

Propriétés

elements

Panneau "Éléments".

sources

Panneau "Sources".

themeName

Chrome 59 et versions ultérieures

Nom du thème de couleur défini dans les paramètres des outils de développement de l'utilisateur. Valeurs possibles : default (par défaut) et dark.

Type

chaîne

Méthodes

create()

chrome.devtools.panels.create(
  title: string,
  iconPath: string,
  pagePath: string,
  callback?: function,
)
: void

Crée un panneau d'extension.

Paramètres

  • titre

    chaîne

    Titre affiché à côté de l'icône de l'extension dans la barre d'outils des outils pour les développeurs.

  • iconPath

    chaîne

    Chemin d'accès à l'icône du panneau par rapport au répertoire de l'extension.

  • pagePath

    chaîne

    Chemin de la page HTML du panneau par rapport au répertoire de l'extension.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (panel: ExtensionPanel) => void

    • panneau

      Objet ExtensionPanel représentant le panneau créé.

openResource()

chrome.devtools.panels.openResource(
  url: string,
  lineNumber: number,
  columnNumber?: number,
  callback?: function,
)
: void

Demande aux outils pour les développeurs d'ouvrir une URL dans un panneau d'outils pour les développeurs.

Paramètres

  • url

    chaîne

    URL de la ressource à ouvrir.

  • lineNumber

    Total

    Spécifie le numéro de ligne vers lequel faire défiler la page lorsque la ressource est chargée.

  • columnNumber

    number facultatif

    Chrome 114 et versions ultérieures

    Spécifie le numéro de colonne vers lequel faire défiler la page lorsque la ressource est chargée.

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    () => void

setOpenResourceHandler()

chrome.devtools.panels.setOpenResourceHandler(
  callback?: function,
)
: void

Spécifie la fonction à appeler lorsque l'utilisateur clique sur un lien de ressource dans la fenêtre "Outils de développement". Pour annuler la définition du gestionnaire, appelez la méthode sans paramètre ou transmettez null en tant que paramètre.

Paramètres

  • callback

    function facultatif

    Le paramètre callback se présente comme suit :

    (resource: Resource, lineNumber: number) => void

    • ressource

      Objet devtools.inspectedWindow.Resource pour la ressource sur laquelle l'utilisateur a cliqué.

    • lineNumber

      Total

      Indique le numéro de ligne de la ressource sur laquelle l'utilisateur a cliqué.