Предоставьте пользователям варианты, Предоставьте пользователям варианты

Точно так же, как расширения позволяют пользователям настраивать браузер Chrome, страница параметров позволяет настраивать расширение. Используйте параметры, чтобы включить функции и позволить пользователям выбирать, какие функции соответствуют их потребностям.

Поиск страницы параметров

Пользователи могут получить доступ к странице параметров по прямой ссылке или щелкнув правой кнопкой мыши значок расширения на панели инструментов и выбрав параметры. Кроме того, пользователи могут перейти на страницу параметров, сначала открыв chrome://extensions , найдя нужное расширение, нажав «Подробнее» , а затем выбрав ссылку «Параметры».

Ссылка на страницу параметров в пользовательском интерфейсе
Ссылка на страницу параметров.
Страница «Параметры контекстного меню»
Щелкните правой кнопкой мыши значок расширения.

Напишите страницу параметров

Ниже приведен пример страницы параметров:

параметры.html:

<!DOCTYPE html>
<html>
  <head>
    <title>My Test Extension Options</title>
  </head>
  <body>
    <select id="color">
      <option value="red">red</option>
      <option value="green">green</option>
      <option value="blue">blue</option>
      <option value="yellow">yellow</option>
    </select>

    <label>
      <input type="checkbox" id="like" />
      I like colors.
    </label>

    <div id="status"></div>
    <button id="save">Save</button>

    <script src="options.js"></script>
  </body>
</html>

Ниже приведен пример сценария опций. Сохраните его в той же папке, что и options.html . Это сохраняет предпочтительные параметры пользователя на всех устройствах с помощью API storage.sync .

варианты.js:

// Saves options to chrome.storage
const saveOptions = () => {
  const color = document.getElementById('color').value;
  const likesColor = document.getElementById('like').checked;

  chrome.storage.sync.set(
    { favoriteColor: color, likesColor: likesColor },
    () => {
      // Update status to let user know options were saved.
      const status = document.getElementById('status');
      status.textContent = 'Options saved.';
      setTimeout(() => {
        status.textContent = '';
      }, 750);
    }
  );
};

// Restores select box and checkbox state using the preferences
// stored in chrome.storage.
const restoreOptions = () => {
  chrome.storage.sync.get(
    { favoriteColor: 'red', likesColor: true },
    (items) => {
      document.getElementById('color').value = items.favoriteColor;
      document.getElementById('like').checked = items.likesColor;
    }
  );
};

document.addEventListener('DOMContentLoaded', restoreOptions);
document.getElementById('save').addEventListener('click', saveOptions);

Наконец, добавьте разрешение "storage" в файл манифеста расширения:

манифест.json:

{
  "name": "My extension",
  ...
  "permissions": [
    "storage"
  ]
  ...
}

Объявить поведение страницы параметров

Существует два типа страниц параметров расширения: полностраничные и встроенные . Тип страницы параметров определяется тем, как она объявлена ​​в манифесте.

Полные параметры страницы

Полноэкранная страница параметров отображается в новой вкладке. Зарегистрируйте HTML-файл параметров в манифесте в поле "options_page" .

манифест.json:

{
  "name": "My extension",
  ...
  "options_page": "options.html",
  ...
}
Полные параметры страницы
Полные параметры страницы в новой вкладке.

Встроенные опции

Страница встроенных параметров позволяет пользователям настраивать параметры расширения, не переходя со страницы управления расширениями внутри встроенного окна. Чтобы объявить встроенные параметры, зарегистрируйте HTML-файл в поле "options_ui" манифеста расширения, при этом для ключа "open_in_tab" установлено значение false .

манифест.json:

{
  "name": "My extension",
  ...
  "options_ui": {
    "page": "options.html",
    "open_in_tab": false
  },
  ...
}
Встроенные опции
Встроенные варианты.
page (строка)
Указывает путь к странице параметров относительно корня расширения.
open_in_tab (логическое значение)
Указывает, будет ли страница параметров расширения открыта в новой вкладке. Если установлено значение false , страница параметров расширения встраивается в chrome://extensions , а не открывается на новой вкладке.

Рассмотрим различия

Страницы параметров, встроенные в chrome://extensions имеют небольшие отличия в поведении от страниц параметров на вкладках.

Ссылка на страницу опций

Расширение может напрямую ссылаться на страницу параметров, вызывая chrome.runtime.openOptionsPage() . Например, его можно добавить во всплывающее окно:

всплывающее окно.html:

<button id="go-to-options">Go to options</button>
<script src="popup.js"></script>

всплывающее окно.js:

document.querySelector('#go-to-options').addEventListener('click', function() {
  if (chrome.runtime.openOptionsPage) {
    chrome.runtime.openOptionsPage();
  } else {
    window.open(chrome.runtime.getURL('options.html'));
  }
});

API вкладок

Поскольку код встроенных параметров не размещается на вкладке, API вкладок использовать невозможно. Вместо этого используйте runtime.connect() и runtime.sendMessage() , если странице параметров необходимо манипулировать содержащейся вкладкой.

API обмена сообщениями

Если страница параметров расширения отправляет сообщение с помощью runtime.connect() или runtime.sendMessage() , вкладка отправителя не будет установлена, а URL-адрес отправителя будет URL-адресом страницы параметров.

Размеры

Встроенные параметры должны автоматически определять свой размер в зависимости от содержимого страницы. Однако встроенный блок может не подходить по размеру для некоторых типов контента. Эта проблема наиболее распространена на страницах параметров, форма содержимого которых регулируется в зависимости от размера окна.

Если это проблема, укажите фиксированные минимальные размеры для страницы параметров, чтобы гарантировать, что встроенная страница найдет подходящий размер.