Tworzenie menu kontekstowego

Menu kontekstowe pojawia się po kliknięciu alternatywnym (często nazywanym kliknięciem prawym przyciskiem myszy). Aby utworzyć menu kontekstowe, najpierw dodaj "contextMenus" uprawnienie do pliku manifest.json.

manifest.json:

  "permissions": [
    "contextMenus"
  ],

Opcjonalnie możesz użyć klucza "icons", jeśli chcesz wyświetlić ikonę obok elementu menu. W tym przykładzie element menu rozszerzenia „Global Google Search” używa ikony o wymiarach 16 x 16 pikseli.

Pozycja menu kontekstowego z ikoną o wymiarach 16 x 16 pikseli.
Element menu kontekstowego z ikoną o wymiarach 16 x 16 pikseli.

Pozostała część tego przykładu pochodzi z przykładu menu kontekstowego Global Google Search, który zawiera kilka opcji menu kontekstowego. Gdy rozszerzenie zawiera więcej niż 1 menu kontekstowe, Chrome automatycznie zwija je w jedno menu nadrzędne, jak pokazano poniżej:

Zagnieżdżone menu kontekstowe.
Rysunek 4: Menu kontekstowe i zagnieżdżone podmenu.

Przykład pokazuje to, wywołując contextMenus.create() w skrypcie service worker rozszerzenia. Elementy podmenu są importowane z pliku locales.js. Następnie runtime.onInstalled iteruje po nich.

service-worker.js:

const tldLocales = {
  'com.au': 'Australia',
  'com.br': 'Brazil',
  ...
}

chrome.runtime.onInstalled.addListener(async () => {
  for (let [tld, locale] of Object.entries(tldLocales)) {
    chrome.contextMenus.create({
      id: tld,
      title: locale,
      type: 'normal',
      contexts: ['selection'],
    });
  }
});