Часто проверяйте эту страницу, чтобы узнать об изменениях в расширениях Chrome, документации по расширениям, соответствующей политике или других изменениях. Другие уведомления вы найдете в группе расширений Google . В расписании Chrome указаны даты выпуска стабильных и бета-версий.
Сообщение в блоге: новое меню расширений
На Google I/O 2024 мы поделились некоторыми ранними проектами предстоящих изменений в меню расширений, которые дают пользователям больше контроля над сайтами, к которым могут получить доступ расширения. В ближайшее время мы собираемся начать тестирование этих изменений, начав с небольшого процента пользователей на Канарских островах и надеясь распространить их более широко в будущем.
Мы также представляем API chrome.permissions.addHostAccessRequest()
.
Читайте больше в нашем сообщении в блоге .
Chrome 132: новое замороженное свойство в API в таблицах
Начиная с Chrome 132, свойство frozen
в API вкладок указывает, была ли вкладка «заморожена» браузером. Сообщения, отправленные на замороженные вкладки, будут помещены в очередь и обработаны, когда вкладка будет разморожена.
Быстрый API в расширении хрома
Prompt API для расширений теперь доступен в пробной версии, поэтому вы можете создавать в браузере расширения Chrome, использующие Gemini Nano, нашу самую эффективную языковую модель.
Присоединяйтесь к пробной версии Prompt API Origin, работающей в Chrome 131–136, и поделитесь своими отзывами. Ваш вклад может напрямую повлиять на то, как мы создаем и реализуем будущие версии этого API, а также всех встроенных API-интерфейсов искусственного интеллекта.
Сообщение в блоге: Что происходит с расширениями Chrome, октябрь 2024 г.
Пришло время еще раз рассказать о том, что происходит с расширениями Chrome: у нас есть интересные новости об интеграции искусственного интеллекта, новых API, мероприятиях и видео. Прочтите все об этом в октябрьском выпуске «Что происходит с расширениями Chrome» !
Присоединяйтесь к встроенному AI Challenge
Chrome запустил конкурс «Встроенный искусственный интеллект»: вам предлагается создавать инновационные веб-приложения и расширения Chrome, используя интегрированные модели искусственного интеллекта и API Chrome , и у вас есть шанс выиграть призы на общую сумму 65 000 долларов США.
Зарегистрируйтесь и получите дополнительную информацию на веб-сайте Integrated AI Challenge . Нам не терпится увидеть, что вы создадите, наполнив Интернет искусственным интеллектом!
Chrome 130: action.onUserSettingsChanged
Начиная с Chrome 130, доступно событие action.onUserSettingsChanged . Это следует из предложения группы сообщества WebExtensions. Спасибо Microsoft за вклад в Chromium.
Chrome 130: StorageArea.getKeys()
Начиная с Chrome 130, метод getKeys() доступен в интерфейсе StorageArea, используемом API chrome.storage
. Это следует из предложения группы сообщества WebExtensions.
Chrome 128: сопоставление заголовка ответа в декларативном сетевом запросе
Начиная с Chrome 128, мы добавляем поддержку сопоставления заголовков ответов в API декларативного сетевого запроса. Это был распространенный запрос, особенно для сопоставления заголовка Content-Type, и мы разработали подходящий API вместе с группой сообщества WebExtensions.
Мы обновили нашу ссылку на API, включив в нее новые поля responseHeaders
и excludedResponseHeaders
. Вы можете использовать их для проверки существования и значения данного заголовка.
В рамках этого обновления мы добавили в нашу документацию новый раздел оценки правил , в котором объясняется, как сопоставляются правила. В частности, для сопоставления заголовков правила могут выполняться только после получения заголовков ответа, поэтому они применяются на более позднем этапе, чем другие правила. Это означает, что запрос доходит до сервера, прежде чем блокируется или перенаправляется.
Видео: Что такое сценарии контента?
Узнайте о сценариях контента в расширениях Chrome, в том числе о том, как зарегистрировать CSS и JavaScript для запуска на определенной странице. Посмотрите полное видео .
Важные обновления политики
Команда Интернет-магазина Chrome опубликовала серию обновлений на странице «Правила программы для разработчиков», призванных стимулировать разработку высококачественных продуктов, предотвращать мошенническое поведение и обеспечивать информированное согласие пользователей. Ребекка Соарес, менеджер по политике Интернет-магазина Chrome, обобщила все обновления в статье «Расширения Chrome: важные обновления политики» .
Сообщение в блоге: Что происходит с расширениями Chrome, июль 2024 г.
За последние три месяца мы выпустили несколько значительных обновлений и новых функций, включая начало поэтапного отказа от Manifest V2. Узнайте больше о том, что происходит в расширениях Chrome, июльский выпуск !
Видео: Что такое удаленно размещенный код?
Патрик из команды расширений Chrome объясняет концепцию удаленно размещенного кода (RHC) в расширениях Chrome. Узнайте, почему RHC больше не разрешен, как это обнаружить и что делать, если ваше расширение необходимо обновить. Посмотрите полное видео .
Chrome 127: новый API action.openPopup
Начиная с Chrome 127, API action.openPopup
доступен для всех расширений. Раньше он был доступен только в Canary или для расширений, установленных политикой.
Видео: Интервью с командой доверия и безопасности
Команда Chrome Extensions DevRel встретилась с командой Trust & Safety, которая проводит проверку в Интернет-магазине Chrome, чтобы задать вам вопросы. Посмотрите полное видео .
Сообщение в блоге: Начало поэтапного отказа от Manifest V2
Начиная с 3 июня на каналах Chrome Beta, Dev и Canary, если у пользователей все еще установлены расширения Manifest V2, некоторые из них начнут видеть предупреждающий баннер при посещении страницы управления расширениями - chrome://extensions - информирующий их о том, что некоторые (Manifest V2) установленные ими расширения вскоре перестанут поддерживаться. Подробности читайте в официальном сообщении.
Обновления пользовательского интерфейса боковой панели
Недавно мы внесли некоторые изменения в пользовательский интерфейс боковой панели, в том числе добавили значок булавки и удалили глобальный значок на боковой панели. Узнайте больше в PSA и ознакомьтесь с нашей обновленной документацией и образцами .
Сообщение в блоге: Расширения Chrome на Google I/O 2024
Очередной ввод-вывод Google позади, и мы рассмотрели все интересные обновления расширений! Зайдите на YouTube, чтобы посмотреть полное видео , а также прочитайте публикацию в нашем блоге, чтобы узнать о некоторых основных моментах.
Пропустить проверку для соответствующих изменений декларативного сетевого запроса
Интернет-магазин Chrome теперь позволяет пропустить проверку допустимых изменений при использовании API декларативного сетевого запроса. Подробную информацию о праве на участие и о том, как подписаться, можно найти в документации Интернет-магазина Chrome .
DeployPercentage доступен в API Интернет-магазина Chrome.
Недавно мы обновили нашу документацию по API Интернет-магазина Chrome, включив в нее информацию о deployPercentage
, которая позволяет вам назначать процент частичного развертывания. Узнайте о deployPercentage
.
Chrome 126: пробные версии Origin в расширениях
В Chrome 126 представлено новое поле Manifest.json — trial_tokens
, позволяющее вам выбрать использование пробных версий Origin и устаревших пробных версий для всех поверхностей расширений. Прочтите руководство для получения дополнительной информации.
Сообщение в блоге: Что происходит с расширениями Chrome — апрель 2024 г.
Мы опубликовали новое издание « Что происходит в расширениях Chrome» . В посте обсуждается то, над чем команда расширения работала последние несколько месяцев. Сюда входит: откат версии в Интернет-магазине Chrome, улучшенная поддержка Firebase Auth, а также новые запуски и обновления API.
Откат версий на панели разработчика Интернет-магазина Chrome
Откатите расширение до предыдущей опубликованной версии в Интернет-магазине Chrome — без дополнительной проверки! Прочтите сообщение в блоге и документацию для получения дополнительной информации.
Chrome 124: Расширенный API сканирования документов
Расширенный API documentScan
теперь доступен в ChromeOS для обнаружения и получения изображений с подключенных сканеров документов.
Chrome 124: поддержка WebGPU в Service Workers
Начиная с Chrome 124, сервис-воркеры поддерживают WebGPU . Для быстрого начала ознакомьтесь с примером расширения WebGPU .
Chrome 123: API событий поддерживает фильтрацию по блокам CIDR.
API событий теперь поддерживает фильтрацию по блокам бесклассовой междоменной маршрутизации (CIDR). Блок CIDR — это набор IP-адресов, имеющих общий сетевой префикс и одинаковое количество бит. Раньше разработчику, которому требовалось фильтровать несколько IP-адресов, нужно было настроить правило фильтрации для каждого адреса в диапазоне блоков. Now when an extension calls addListener()
, a passed in rule means the event handler will only be called when the host part of a URL is an IP address and is contained in any of the CIDR blocks specified in an array.
Интернет-магазин Chrome: изменения в требованиях к длине имени расширения
В Интернет-магазине Chrome теперь существует универсальное ограничение в 75 символов для поля "name"
расширения в файле манифеста.json. Раньше ограничение для английского языка составляло 45 символов, а в других локалях ограничений на поле "name"
не было.
Первоначально это было предназначено для учета культурных и языковых различий, которые невозможно отразить одним и тем же количеством символов. К сожалению, эта функция использовалась небольшим количеством разработчиков для рассылки спама в магазине. В результате мы вводим новый универсальный лимит — увеличение до 75 символов. Это ограничение распространяется почти на все расширения, имеющиеся на сегодняшний день в магазине, поэтому, скорее всего, в результате этого изменения от вас не потребуется никаких действий. Если вы попытаетесь загрузить расширение, имя которого превышает максимальный лимит, загрузка будет заблокирована магазином.
Сообщение в блоге: путь Eyeo к тестированию приостановки сервисных работников
В этом посте команды Eyeo Extension Engine мы исследуем проблему тестирования работников служб расширений. В Манифесте V2 расширения размещались на фоновой странице, которая активна на протяжении всего жизненного цикла расширения. Вместо этого в Manifest V3 используются сервисные работники, а сервисные работники по замыслу экономят ресурсы, отключаясь, когда они не нужны. Это создает определенные проблемы при тестировании. В этом посте объясняется, как Eyeo справился с этими проблемами .
Chrome 123: будильники теперь срабатывают, когда устройство находится в спящем режиме.
Сигналы тревоги, установленные с помощью API chrome.alarms
, больше не задерживаются, когда устройство переходит в спящий режим. Когда устройство выйдет из режима сна, будильник сработает один раз, независимо от того, сколько сигналов было пропущено. Например, предположим, что будильник настроен на срабатывание один раз в час, а устройство, на котором он установлен, спит с 00:55 до 2:05, тогда только будильник в 2:00 вызывает событие onAlarm
. Он сработает как можно ближе к 2:00 ночи и сразу же, когда устройство проснется, если оно спит.
Это изменение приводит Chrome в соответствие с поведением, согласованным в группе сообщества веб-расширений.
Сообщение в блоге: Изменения в поведении bfcache с портами сообщений расширения
Кэш назад/вперед (bfcache) — это оптимизация браузера, обеспечивающая мгновенную навигацию вперед и назад. Начиная с Chrome 123, когда страница с открытым портом расширения хранится в bfcache, канал сообщений закрывается, а это означает, что на эту страницу не будут отправляться никакие сообщения. Следовательно, сценарии расширения должны прослушивать события жизненного цикла, такие как onDisconnect
, и устанавливать новое соединение при восстановлении страницы из BFCache.
Дополнительные сведения и пример кода см. в разделе Изменения в поведении BFCache с портами сообщений расширения .
Chrome 122: обещание поддержки API асинхронных расширений
Мы завершили реализацию поддержки Promise для всех методов API асинхронных расширений. Это было сделано для модернизации методов API за счет улучшения эргономики работы с асинхронными операциями. Несколько методов (например, desktopCapture.chooseDesktopMedia()
) продолжают поддерживать только обратные вызовы, поскольку их текущие поверхности несовместимы с Promises. Для обратной совместимости по-прежнему поддерживаются обратные вызовы. Если вы обнаружите, что обещание не работает, сообщите об ошибке .
Новое руководство по общению в режиме реального времени
Мы только что опубликовали руководства по опциям расширений в режиме реального времени . Обновления в реальном времени обеспечивают мгновенный путь связи с ваших серверов непосредственно к установленным вами расширениям. Кроме того, у нас есть новое руководство по использованию chrome.gcm , Web Push .
Новое руководство и образец: завершение тестирования сервисного работника
Мы только что опубликовали руководство о том, как протестировать завершение сервисного работника с помощью Puppeteer . Сопровождающий пример демонстрирует это в Puppeteer и Selenium.
Обновленный образец встроенного обмена сообщениями
Мы только что опубликовали обновленный образец встроенного обмена сообщениями. Этот API позволяет вашему расширению запускаться и взаимодействовать с другим приложением. Спасибо участнику GitHub Шубхам-Расалу за работу над этим.
Chrome 121: новое свойство LastAccessed на вкладках.Tab
К объекту tabs.Tab
было добавлено новое свойство с именем lastAccessed
. Это свойство указывает, когда вкладка была активирована в последний раз. Возвращаемое значение находится в миллисекундах с начала эпохи.
Chrome 121: неподдерживаемые «фоновые» клавиши теперь выдают предупреждение
При переходе от Манифеста V2 к Манифесту V3 дочерние элементы "background"
ключа манифеста были изменены, чтобы обеспечить замену фоновых сценариев рабочими службами расширений. Раньше добавление ключей Manifest V2 "scripts"
, "page"
или "persistent"
к "background"
ключу расширения Manifest V3 приводило к ошибке. Присутствие этих ключей теперь вызывает предупреждение.
Это делается для того, чтобы можно было использовать один файл манифеста в расширениях в нескольких браузерах по предложению в группе сообщества .
Chrome 120: минимальная детализация сигналов тревоги уменьшена до 30 секунд.
Начиная с Chrome 120, расширения Manifest V3 могут использовать API chrome.alarms
с задержками или периодами в 30 секунд, а не требовать значений в 60 секунд и более.
Сообщение в блоге: Возобновление перехода на Manifest V3
График поддержки Manifest V2 был обновлен. Подробности читайте в нашем блоге за ноябрь 2023 г.
Сообщение в блоге: Улучшения в поддержке фильтрации контента в Manifest V3
Узнайте о том, как мы улучшили API declarativeNetRequest, в нашем новом посте в блоге .
Сообщение в блоге: Что нового в Chrome 120 для расширений
Chrome 120 Beta была недавно выпущена. Краткое описание важных обновлений, касающихся разработчиков расширений, можно найти в нашей новой записи в блоге: Что нового в Chrome 120 для расширений . Этот выпуск также знаменует собой важную веху, поскольку он удаляет последние два элемента (пользовательские сценарии и обработчик файлов в ChromeOS) из списка критических недостатков платформы .
PSA: изменение обработки URL-адресов политики конфиденциальности на панели разработчика.
Политики конфиденциальности на панели разработчика теперь добавляются на уровне элементов. Это позволяет вам предоставлять разную политику конфиденциальности для каждого элемента. Подробнее об этом изменении читайте в нашем PSA .
Видео: Беседа с Мэттом Фрисби
Мы только что опубликовали новое видео на YouTube-канале Chrome для разработчиков, в котором беседуем с экспертом Google Developer и автором Мэттом Фрисби. Посмотрите это здесь .
Новое руководство по тестированию расширений
Мы только что опубликовали новое руководство по написанию автоматических тестов для расширений, в том числе по написанию модульных тестов , а также общее руководство и руководство по сквозному тестированию.
Сообщение в блоге: Что происходит с расширениями Chrome – октябрь 2023 г.
Мы только что опубликовали второе издание книги «Что происходит с расширениями Chrome» . В посте обсуждается то, над чем команда расширения работала в течение последних нескольких месяцев, в том числе над решением проблем стабильности сервис-воркеров и достижением хорошего прогресса в устранении всех пробелов в платформе MV3. Мы также делимся интересными предстоящими выпусками API, такими как API списка чтения и API пользовательских сценариев.
Увеличены ограничения статического набора правил в API декларативного сетевого запроса.
Следуя отзывам группы сообщества веб-расширений, мы значительно увеличиваем ограничение на количество включенных статических наборов правил с 10 до 50. Кроме того, мы увеличиваем общее количество разрешенных статических наборов правил с 50 до 100. В настоящее время это доступно на Canary.
Улучшенное руководство по удаленно размещенному коду.
Требование Манифеста V3 заключается в том, что расширения больше не могут использовать удаленно размещенный код. Хотя это было частью нашего руководства по миграции с самого начала, мы подумали, что стоит улучшить руководство по этому вопросу. На этой странице теперь содержится больше информации, описывающей возможности Manifest V3 и предоставляющей дополнительную информацию о стратегиях обновления.
Существует соответствующее дополнение к разделу «Устранение нарушений в Интернет-магазине Chrome» . В новом разделе описаны распространенные причины отклонения расширений с удаленно размещенным кодом.
Chrome 118: isUrlFilterCaseSensitive теперь по умолчанию имеет значение false
Начиная с Chrome 118, свойство isUrlFilterCaseSensitive
в API chrome.declarativeNetRequest было изменено со значения по умолчанию на false
. Если вы хотите сохранить старое поведение, вы можете явно установить для isUrlFilterCaseSensitive
значение true
в правилах declarativeNetRequest.
Это следует за обсуждениями в группе сообщества веб-расширений. Firefox и Safari уже реализовали подобное изменение.
Документация по файлам cookie и API веб-хранилища
Мы опубликовали новое руководство о том, как файлы cookie и API веб-хранилища работают в расширениях Chrome . Он включает подробную информацию об изменениях в разделах файлов cookie и хранилища в Privacy Sandbox , продолжающемся проекте по отказу от использования сторонних файлов cookie посредством создания серии новых API-интерфейсов веб-платформы, а также подробную информацию о том, как они работают в расширениях.
Образцы расширений теперь доступны для поиска
Недавно мы создали страницу, на которой можно искать образцы расширений Chrome . Страница поиска имеет несколько опций. Поле поиска позволяет искать текст в примерах заголовков. Вы можете ограничить поиск по разрешению или расширению API. Дополнительный фильтр позволяет ограничить поиск примерами API или функциональными примерами (вариантами использования).
Этот новый образец страницы был создан Сюэчжоу Даем, участником Google Summer of Code, который также предоставил несколько новых примеров. Вы можете прочитать об их впечатлениях этим летом в их посте в нашем блоге .
Как и раньше, наши примеры кода по-прежнему доступны на GitHub для клонирования или разветвления.
Chrome 118: изменения в открытии файла: URL-адреса схемы
Начиная с Chrome 118, расширениям потребуется включить настройку «Разрешить доступ к URL-адресам файлов» на странице chrome://extensions
, чтобы открывать URL-адреса схемы file:// с помощью вкладок или API-интерфейсов Windows . Вы можете программно проверить этот доступ, вызвав chrome.extension.isAllowedFileSchemeAccess()
. Firefox уже ограничивает URL-адреса файлов, и Safari поддерживает это изменение. Подробнее читайте в посте в группе Google по расширениям .
Chrome 117: расширенная защита URL-адресов при навигации по API расширений
Ранее навигация, запускавшаяся из вызовов API расширения для tabs.update()
, tabs.create()
и windows.create()
выдавала ошибку для некоторых URL-адресов chrome://. Кроме того, был запрещен вызов tabs.update()
с URL-адресом JavaScript. В версии 117 эта защита URL-адресов JavaScript была расширена до метода tabs.create()
, а ряд дополнительных URL-адресов chrome:// был добавлен в список запрещенных URL-адресов, который применяется ко всем ранее упомянутым методам.
Улучшенное руководство для API declarativeNetRequest.
API chrome.declarativeNetRequest
блокирует или изменяет сетевые запросы, определяя декларативные правила. Это позволяет расширениям изменять сетевые запросы, не перехватывая их и не просматривая их содержимое, обеспечивая тем самым большую конфиденциальность пользователей. Его также сложно использовать. Учитывая это, мы переписали руководство таким образом, чтобы, по нашему мнению, дать более четкое представление о том, как реализовать декларативные наборы правил. Читайте новый раздел по ссылке выше.
Использование учетной записи Google Analytics в Интернет-магазине Chrome
Интернет-магазин Chrome предлагает интеграцию с Google Analytics, что позволяет вам видеть аналитику для вашего списка в Интернет-магазине Chrome в дополнение к представлению, предлагаемому на панели разработчика. Дополнительную информацию см. в статье Использование учетной записи Google Analytics в Интернет-магазине Chrome .
Chrome 115: DevTools по умолчанию обрабатывает сценарии контента
Скрипты внедренного контента теперь по умолчанию находятся в списке игнорирования DevTools. Это не влияет на точки останова, но означает, что сценарии содержимого будут пропускаться во время отладки, а исключения из этих сценариев будут игнорироваться. Когда сценарий контента открыт на вкладке «Источники» , баннер предупреждает вас, если он включен, и предоставляет возможность удалить сценарий контента из списка игнорирования. Чтобы отключить это поведение, откройте DevTools, перейдите в «Настройки» , затем «Список игнорирования» . Чтобы узнать больше, посмотрите , что нового в Devtools .
Бета-версия Chrome 116: здесь больше, чем мы можем разместить
Chrome 116 — это большой выпуск расширений. Теперь боковые панели можно открывать программно. Новый метод позволяет узнать, есть ли активный закадровый документ. Сервисные работники получили несколько улучшений. В 116 достаточно улучшений, и мы написали о них статью в блоге . Chrome 116 находится в стадии бета-тестирования с 19 июля.
Сообщение в блоге: Что происходит с расширениями Chrome
Мы только что опубликовали обзор изменений и улучшений расширений этого года. В статье обсуждаются важные новые функции года, в том числе API боковой панели, улучшения сервис-воркеров и закадровые документы. Вы также сможете узнать, над чем мы работаем в этом квартале. В статье перечислено гораздо больше, со ссылками на все.
Новое руководство и образец: узнайте, как использовать Google Analytics 4 в расширении Chrome.
Мы опубликовали новые руководства и примеры по Google Analytics и геолокации:
- Обновленная версия нашего руководства по Google Analytics, объясняющая, как использовать Google Analytics 4 в расширении Chrome. Мы также добавили рабочий образец Google Analytics 4 в наш репозиторий образцов Github. Посетите
google-analytics.js
чтобы найти соответствующий код, связанный с Google Analytics. - Новое руководство по геолокации и три примера, демонстрирующие, как получить доступ к геолокации в сервис-воркерах, скриптах контента, всплывающих окнах и боковых панелях.
Chrome 115: укажите несколько причин в chrome.offscreen.createDocument().
Теперь вы можете указать несколько перечислений reason
при вызове chrome.offscreen.createDocument()
. Используйте это, когда закадровый документ будет использоваться для разных целей. Браузер использует предоставленные причины для определения срока жизни закадрового документа.
Новый инструмент: Инструмент тестирования обновлений расширений.
We've just released the Extension Update Testing Tool , a local extension update server that can be used for testing updates to Chrome Extensions during local development, including permission grants. Инструмент показывает поток обновлений пользователя, включая сохранение отключенного расширения до тех пор, пока пользователь не предоставит новые запрошенные разрешения. Этот инструмент особенно полезен для моделирования изменений разрешений, запрашиваемых при обновлении расширения с Manifest V2 на Manifest V3.
Chrome 114: новый API боковой панели
Представляем новый API боковой панели — сопутствующую поверхность, которая позволяет пользователям получать доступ к инструментам наряду с содержимым, которое они просматривают. Чтобы узнать больше, посетите справку по API боковой панели . Кроме того, мы добавили множество примеров боковых панелей в наш репозиторий образцов GitHub . Мы также рассказываем больше о боковых панелях в новой записи блога «Проектирование превосходного пользовательского опыта с помощью нового API боковой панели» . Наша политика в области рекомендаций по качеству и лучшие практики также были рассмотрены, чтобы предоставить дополнительные рекомендации по созданию высококачественных расширений боковых панелей.
Ваши отзывы важны при разработке этого API; пожалуйста, поделитесь своими мыслями и пожеланиями в группах Chromium . Следите за новыми обновлениями, поскольку мы продолжаем совершенствовать API боковой панели.
Новые примеры: WASM в расширениях
Доступны два новых примера, демонстрирующих использование WASM в расширении:
- Использование WASM в Манифесте V3 показывает общий метод включения модуля WASM.
- Использование WASM в качестве модуля в Манифесте V3 показывает, как использовать его в модуле.
Особая благодарность участнику GitHub @daidr за эти примеры.
Обновленное руководство по миграции манифеста версии 3.
Мы обновили раздел «Известные проблемы» нашего руководства по миграции Manifest V3 , добавив обновленный список пробелов в платформе расширений, которые мы намерены закрыть, прежде чем объявить новый график прекращения поддержки Manifest V2.
Запись аудио и видео с помощью Manifest V3
Мы только что опубликовали новую статью под названием «Запись звука и захват экрана» , в которой рассказывается о записи звука или видео с вкладки, окна или экрана в Manifest V3. В этой статье описываются несколько подходов к записи с использованием API chrome.tabCapture
и функции getDisplayMedia()
.
Chrome 114: увеличена квота Storage.local
Мы увеличили квоту для свойства storage.local
примерно до 10 МБ. Это было согласовано в группе сообщества веб-расширений . Это приводит storage.local
в соответствие с storage.session
, который был изменен в Chrome 112.
Новый учебник по обслуживанию расширения и помощь
Сервисные работники являются неотъемлемой частью расширений Chrome. Мы только что опубликовали руководство, объясняющее основы регистрации, отладки и взаимодействия с Service Workers. Мы также добавили новое руководство для сервисных работников, в котором более подробно объясняются важные концепции. В ближайшие месяцы мы будем расширять этот раздел.
Дополнительные советы по устранению нарушений в интернет-магазине
Чтобы облегчить публикацию в Интернет-магазине Chrome, мы добавили новые рекомендации в двух областях. Рекомендации по минимальной функциональности сосредоточены на предоставлении пользователям преимуществ и расширении их возможностей просмотра. Рекомендации по партнерской рекламе заключаются в том, чтобы информировать пользователей о расширениях, использующих партнерские ссылки или коды для монетизации, и предоставить им определенный контроль, требуя действий пользователя перед включением.
Новые инструкции для конвертера манифеста расширений
Мы переписали файл README для конвертера манифеста расширений , чтобы было проще понять, что вам нужно делать после запуска инструмента. Конвертер помогает перенести расширения, созданные на основе Manifest V2, на Manifest V3. Новый README описывает, что делает инструмент, используя слова, которые точно соответствуют словам, указанным в контрольном списке руководства по миграции . Конвертер не делает всего, но он устраняет многие задачи, которые не требуют человеческого вмешательства.
Chrome 113: новые причины использования закадровых документов
Мы добавили два новых типа причин в API Offscreen Documents. Используйте LOCAL_STORAGE
для доступа к API localStorage веб-платформы. Используйте WORKER
при создании веб -работников.
Google Analytics 4 теперь на панели разработчика
Панель инструментов разработчика Интернет-магазина Chrome теперь поддерживает Google Analytics 4 (GA4). Мы упростили настройку Google Analytics и упростили управление доступом для издателей групп. Если вы ранее использовали Google Universal Analytics для отслеживания активности на странице вашего приложения, вам необходимо принять меры до 1 июля 2023 года, чтобы гарантировать, что вы продолжите получать данные о своей странице в магазине. Дополнительную информацию можно найти в сообщении в группе Google по расширениям Chromium .
API обработки файлов приходит в Chromeos
API-интерфейс File Handler доступен для экспериментов в ChromeOS в Canary версий 112 и 113. Он позволяет расширениям ChromeOS открывать файлы с указанными типами MIME и расширениями файлов. Чтобы реализовать обработку файлов, добавьте в manifest.json
набор правил. Эта функция работает так же, как и для прогрессивных веб-приложений. Для получения дополнительной информации см. статью в другом месте на этом сайте.
Чтобы включить обработку файлов:
- Начиная с 112, запустите Chrome, используя флаг
--enable-features=ExtensionWebFileHandlers
, начиная с 112. - Начиная с 113, вставьте
os://flags/#extension-web-file-handlers
в омнибокс Chrome и выберите «Включено» в раскрывающемся меню.
Мы надеемся запустить эту функцию в Chrome 115 в конце июня. Следите за обновлениями в этом пространстве.
Новые примеры: динамические объявления и программное внедрение.
Мы создали новый образец API chrome.scripting
. Он демонстрирует динамические объявления, когда сценарий содержимого регистрируется во время выполнения, и программное внедрение, когда сценарий выполняется на уже открытой вкладке.
Новые примеры: варианты использования декларативных сетевых запросов
Доступны три новых образца, демонстрирующих API Declarative Net Request . Каждый демонстрирует реализацию одного варианта использования. Первый показывает, как заблокировать файлы cookie. Остальные два демонстрируют блокировку и перенаправление URL-адресов.
Chrome 112: увеличена квота Storage.session.
В Chrome 112 квота свойства storage.session
увеличена примерно до 10 МБ. Это было согласовано в группе сообщества веб-расширений: https://github.com/w3c/webextensions/issues/350.
Chrome 109: Документы за кадром
Закадровые документы теперь доступны в расширениях Manifest V3. Они помогают перейти от фоновых страниц к работникам служб расширений, обеспечивая поддержку функций и API, связанных с DOM. Для получения дополнительной информации прочитайте сообщение в блоге .
Chrome 110: включено ли расширение?
Метод chrome.action.isEnabled()
программно проверяет, включено ли расширение для конкретной вкладки. Это избавит вас от необходимости поддерживать включенное состояние ваших вкладок. Этот новый метод принимает идентификатор вкладки и ссылку на обратный вызов и возвращает логическое значение. У него есть одно ограничение: вкладки, созданные с использованием chrome.declarativeContent
всегда возвращают false.
(В пространстве имен chrome.action
недавно появились новые методы для управления внешним видом значков расширений. Дополнительную информацию см. в разделе Настройка цветов значков .)
Chrome 110: изменение тайм-аута простоя сервисного работника
Раньше работник службы расширения часто отключался через пять минут. Мы изменили это поведение, чтобы оно больше напоминало время жизни сервис-воркера в Интернете. Работник службы расширения будет отключен либо через тридцать секунд бездействия, либо если обработка одного действия займет более 5 минут. Дополнительные сведения см. в разделе Увеличение срока службы работника службы расширений .
Сообщение: Приостановка вывода из эксплуатации Manifest V2
Сроки прекращения поддержки Manifest V2 находятся на рассмотрении, а эксперименты, запланированные на начало 2023 года, откладываются. Для получения дополнительной информации читайте обновление в группе Google по хром-расширениям.
Chrome 110: настройка цветов значков
В пространстве имен chrome.action
появилось два новых метода, которые дают вам больше контроля над значками расширения внешнего вида. Методы setBadgeTextColor()
и getBadgeTextColor()
позволяют расширению изменять и запрашивать цвет текста значка значка на панели инструментов. При использовании с setBadgeBackgroundColor
и getBadgeBackgroundColor
эти новые методы позволяют обеспечить согласованность дизайна и бренда.
Сообщение в блоге: Более подробная информация о переходе на Manifest V3
Мы уточнили сроки прекращения поддержки Manifest V2 . График поддержки Manifest V2 также был обновлен с учетом этой информации.
Обновление документации: известные проблемы при переходе на Manifest V3.
Мы собрали список основных функций, которые в настоящее время находятся в разработке, и выявленных ошибок . Наша цель на этой странице — помочь разработчикам лучше понять текущее состояние платформы и то, на какие функции они могут ориентироваться, готовясь к будущему.
Интернет-магазин Chrome: удалена загрузка изображения «большая рекламная плитка»
Интернет-магазин Chrome удалил пользовательский интерфейс загрузки «большой рекламной плитки» с вкладки «Список товаров» на панели разработчика. Это изменение не влияет на опыт конечного пользователя, так как эти изображения не использовались в пользовательском интерфейсе потребителя. Смотрите этот пост хрома-эксплуата для получения дополнительной информации.
Chrome 106: разрешить страницы в файле: // URL -адреса для доступа к веб -доступным ресурсам
Сопровочные происхождения, такие как iframes и динамический импорт, также должны иметь доступ к веб -доступным ресурсам, согласно crbug.com/1219825#c11 .
Chrome 106: Исправлена ошибка, разрешающая неверные окончательные аргументы на некоторых функциях ASYNC API
Ранее Manifest V3 APIS ASINC API может обеспечить неверный окончательный аргумент, а Chrome не ошибся. С этим исправлением Chrome теперь будет правильно ошибочно и сообщит, что не было подходящей подписи. Разработчикам рекомендуется проверить свои расширения на канарейке на предмет любых ошибок, если они случайно используют неправильную подпись для вызова API, который будет нарушен этим исправлением ошибки.
Сообщение в блоге: Revamp Analytics Chrome Web Store
Chrome Web Store имеет обновленный опыт анализа предметов для приборной панели разработчика Chrome Web Store. Новую панель инструментов легче понять с первого взгляда и объединяет наиболее полезную информацию впереди. Прочитайте сообщение в блоге для получения дополнительной информации.
Chrome 105: обещания для API идентичности
Функции на API Identity теперь поддерживают вызовы на основе перспективных обещаний. Это происходит с небольшим изменением на поверхности для identity.getAuthToken()
, где асинхронная возврата установлена на вызов на основе перспектива, основанный на обещаниях, будет иметь «токен» и «предоставленные кнопки» в качестве параметров на одном объекте (в отличие от версии обратного вызова в качестве отдельных аргументов с обратным вызовом).
Chrome 104: New Favicons API для Manifest V3
Расширения Manifest V3 теперь могут получить доступ к любимым видам с использованием нового шаблона URL: chrome-extension://<id>/_favicon/
, гдеchrome://favicons
API. Смотрите документы API Favicon для получения дополнительной информации.
Обновление DOCS: раскрытие Docs Trader/Non Trader
Добавлено идентификацию разработчиков-трейдеров/не торговцев , которая информирует разработчиков, чтобы точно самообладать свой статус трейдера/не торговца.
Chrome 103: Wasm в Manifest V3 требует wasm-unsafe-eval
Chrome больше не предоставляет script-src: wasm-unsafe-eval
по умолчанию. Расширения, которые используют WebAssembly, теперь должны явно добавлять эту директиву и значение в extension_pages
в их объявлениях content_security_policy
.
Chrome 103: Изменение ярлыков MV3 вступает в силу немедленно
При изменении сочетания клавишной клавиши Manifest Extension на chrome://extensions/shortcuts
обновления теперь применяются немедленно. Ранее расширение должно было быть перезагружено до того, как изменение вступит в силу.
Chrome 102: Динамические сценарии контента в основном мире
Динамически зарегистрированные сценарии контента теперь могут указать мир , в который будут введены активы. См. scripting.registerContentScripts()
для деталей.
Chrome 102: новое поле Manifest "optional_host_permissions"
Расширения Manifest V3 теперь могут указывать ключ optional_host_permissions
в MANIFEST.JSON. Это позволяет манифестным расширениям v3 объявлять необязательные шаблоны соответствия для хостов, как только Manifest Extensions может с использованием ключа optional_permissions
.
Chrome 102: Свойство InjectImmed Utry в Scripting.executcript ()
chrome.scripting.executeScript()
теперь принимает дополнительное свойство injectImmediately
а на его аргумент injection
. Если присутствовать и установить на TRUE, сценарий будет вводить в цель как можно скорее, вместо того, чтобы ждать document_idle
. Обратите внимание, что это не гарантия, что скрипт будет вводить до загрузки страницы, так как страница продолжает загружаться, когда производится вызов API.
Chrome 102: поддержка API Omnibox в Manifest v3
API Omnibox теперь может использоваться в расширениях на основе сервисных работников. Ранее некоторые из методов этого API могли бы привлечь к вызову из -за внутренних зависимостей от возможностей DOM.
Chrome 102: wasm-unsafe-eval разрешен в Manifest V3 CSP
Расширения Manifest V3 теперь могут включать в себя wasm-unsafe-eval
в их объявлениях content_security_policy
. Это изменение позволяет Manifest V3 расширениям использовать Webassembly.
Chrome 102: New Storage.session API
Расширения Manifest V3 теперь могут использовать в хранилище памяти.
Обновление DOCS: Krome Web Store Discovery
Discovery on Chrome Web Store дает обзор того, как пользователи находят элементы в веб -магазине Chrome и как наши редакторы выбирают элементы для участия.
Chrome 101: Улучшенные условия домена DeclarativenetRequest
Условия правила DeclarativenEtRequest были обновлены, чтобы разрешить расширениям для лучших целевых запросов на основе доменов «запроса» и «инициатора» запроса. Соответствующими свойствами являются initiatorDomains
, excludedInitiatorDomains
, requestDomains
и excludedRequestDomains
. См. Также эта нить хрома-экстификации .
Chrome 100: Решенная проблема с scripting.executcript () на недавно созданных вкладках
Исправлена давняя проблема, в которой вызов scripting.executeScript()
на недавно созданной вкладке или окне может потерпеть неудачу.
Chrome 100: Нативный порт обмена сообщениями поддерживает обслуживающий работник
Подключение к местному хозяину обмена сообщениями с использованием chrome.runtime.connectNative()
в работнике обслуживания расширения должен поддерживать обслуживающий работник, пока порт открыт.
Chrome 100: Omnibox.setDefaultultsugeggestion () поддерживает обещания и обратные вызовы
Метод omnibox.setDefaultSuggestion()
теперь возвращает обещание или принимает обратный вызов, чтобы позволить разработчикам определить, когда было правильно установлено предложение.
Chrome 100: i18n.getMessage () Поддержка в работниках по расширению работников
API chrome.i18n.getMessage()
теперь поддерживается в контекстах работников службы расширения.
Chrome 99: match_origin_as_fallback в Canary
Скрипты содержимого теперь могут указывать ключ match_origin_as_fallback
, чтобы ввести в кадры, которые связаны с соответствующей кадрой, включая кадры с about:
, data:
blob:
и filesystem:
URL. Смотрите документацию по сценариям контента для деталей.
Chrome 99: Поддержка работников расширения для файла: схемы в Canary
Расширение на основе обслуживания Manifest V2 и Manifest V3 расширения теперь могут использовать API Fetch для запроса file:
-Scheme URL. Доступ к file:
-Scheme URL -адреса по -прежнему требует, чтобы пользователь включил «разрешить доступ к URL -адресам файлов» для расширения на странице chrome://extensions
.
Chrome 99: Обещающая поддержка API обмена сообщениями в Canary
Поддержка обещания была добавлена в tabs.sendMessage
, runtime.sendMessage
и runtime.sendNativeMessage
для расширений, созданных для манифеста v3.
Обновление документов: документация по обзору веб -магазина Chrome
Добавлена новая справочная страница , которая содержит обзор процесса обзора веб -магазина Chrome и объясняет, как осуществляется обеспечение соблюдения политики программы разработчиков .
Chrome 98: scripting.executcript () и scripting.insertcsss () Примите несколько файлов
Методы сценариев API executeScript()
и insertCSS()
теперь принимают несколько файлов. Ранее эти методы требовали массива с одной записью файла.
Обновление DOCS: обзор нарушения обновлений по устранению неполадок
Страница по устранению неисправностей Chrome Web Storation была обновлена, чтобы предоставить разработчикам более подробное руководство по общим причинам отказа.
Chrome 96: Расширенная поддержка перспектива для еще 27 API
Этот релиз содержит значительно больше обновлений перспективы, чем любой предыдущий выпуск. Обновления включают как общие, так и ChromeoS-специфические APIS API. Разверните следующие разделы для деталей.
Расширения APIS
Ряд API теперь поддерживают обещания в Manifest V3.
-
chrome.browsingData
-
chrome.commands
-
chrome.contentSettings
-
chrome.debugger
-
chrome.downloads
-
chrome.enterprise.hardwarePlatform
-
chrome.fontSettings
-
chrome.history
-
chrome.instanceID
-
chrome.permissions
-
chrome.processes
-
chrome.search
-
chrome.sessions
-
chrome.topSites
Кроме того, API, которые используют прототип ChromeSetting
, теперь также поддерживают обещания. На следующие API влияют это изменение.
Chromeos APIS
-
chrome.certificateProvider
-
chrome.documentScan
-
chrome.enterprise.deviceAttributes
-
chrome.enterprise.networkingAttributes
-
chrome.fileBrowserHandler
-
chrome.fileSystemProvider
-
chrome.loginState
-
chrome.printingMetrics
-
chrome.wallpaper
Chrome 96: Динамические сценарии контента
API chrome.scripting
теперь поддерживает регистрацию , обновление , нерегистрирование и получение списка сценариев контента во время выполнения. Previously, content scripts could only be statically declared in an extension's manifest.json or programmatically injected at runtime with chrome.scripting.executeScript()
.
Обновление документов: график поддержки Manifest V2
В этом сообщении Manifest V2 на V3 была объявлена в этом сообщении , и была опубликована более подробная страница временной шкалы .
Chrome 96: DeclarativenetRequestwithhostacccess разрешение
Новое разрешение declarativeNetRequestWithHostAccess
позволяет расширениям использовать API chrome.declarativeNetRequest
на участках, которые расширение имеет разрешения на хост. Это также позволяет существующим растяжениям V2, которые используют webRequest
, webRequestBlocking
и разрешение на хост, специфичное для сайта для перехода на API chrome.declarativeNetRequest
не требуя, чтобы пользователь утверждал новые разрешения.
Chrome 95: сценарии вводите непосредственно на страницы
Метод chrome.scripting
api executeScript()
теперь может вводить сценарии непосредственно в основной мир страницы. Ранее расширения могли вводить только непосредственно в изолированный мир расширения. Для получения дополнительной информации об изолированных мирах см. Документацию по сценариям контента .
Chrome 95: обещание поддержка API хранения
Методы на манифестной версии V3 chrome.storage
API теперь возвращают обещания.
Обновление политики: двухэтапное правоприменение
Сообщение в блоге в блоге, опубликованное 29 июня 2021 года, была обновлена, чтобы исправить двухэтапную временную шкалу развертывания проверки.
Chrome 94: декларативный чистый запрос. Статические изменения правил.
chrome.declarativeNetRequest
теперь поддерживает определение до 50 статических наборов правил ( max_number_of_static_rulesets ) и включает до 10 наборов правил ( max_number_of_enabled_static_rulesets ) за раз.
Chrome 93: Поддержка изоляции поперечного происхождения
Как Manifest V2 , так и Manifest V3 расширения теперь могут выбрать изоляцию поперечного происхождения . Эта функция ограничивает, что ресурсы перекрестного происхождения могут загружать страницы расширения и позволяет использовать функции веб-платформы низкого уровня, такие как SharedArrayBuffer
. Выберите, начиная с Chrome 95.
Обновление политики: обновления политики программы разработчиков
Политики программы разработчиков Chrome Web Store были обновлены с разъяснениями в The Chepective Tactics, Spam и повторяющихся политиках контента. Это обновление также включает в себя новое двухэтапное требование проверки для публикации в веб -магазине Chrome. Прочитайте сообщение в блоге для получения дополнительной информации.
Сообщение в блоге: Действия расширения в Manifest V3
Расширения Chrome имели chrome.browserAction
и chrome.pageActions
API в течение многих лет, но Manifest V3 заменил оба на общий chrome.actions
API. Этот пост исследует историю этих API и то, что изменилось в Manifest V3. Прочитайте пост .
Сообщение в блоге: представление Chrome.scripting
chrome.scripting
API - это новый Manifest V3 API, сфокусированный на сценариях. В этом посте мы копаем мотивы для этого изменения и более внимательно рассмотрим его новые возможности. Прочитайте пост .
Chrome 92: Поддержка модуля обслуживания работников
Chrome теперь поддерживает модули JavaScript у работников обслуживания. Чтобы указать модуль модуль в вашем манифесте:
"background": {
"service_worker": "script.js",
"type": "module"
}
Это загружает сценарий работника как модуль ES, который позволяет использовать ключевое слово import
в скрипте работника для импорта других модулей.
Chrome 91: chrome.action.getusersettings ()
Новый метод chrome.action.getUserSettings()
позволяет расширениям определять, прикрепил ли пользователь расширение к основной панели инструментов.
Chrome 90: Chrome.scripting.removecss ()
Новый метод chrome.scripting.removeCSS()
позволяет расширениям удалять CSS, который ранее был вставлен с помощью chrome.scripting.insertCSS()
. Заменяет chrome.tabs.removeCSS()
.
Chrome 90: Возвращающиеся обещания из Scripting.executcript ()
chrome.scripting.executeScript()
теперь поддерживает возвращающиеся обещания. Если результирующее значение выполнения скрипта является обещанием, Chrome будет ждать обещания урегулировать и вернуть ее полученное значение.
Chrome 90: chrome.scripting.executcriptcript () Результаты включают FrameID
Результаты, возвращаемые из chrome.scripting.executeScript()
теперь включают FrameID . Свойство frameId
указывает на кадр, из -за чего результат, позволяя расширениям легко связать результаты с отдельными кадрами при введении в несколько кадров.
Chrome 89: новый API для управления группами вкладок
Новые API и новые возможности chrome.tabGroups
в chrome.tabs
позволяют расширениям читать и манипулировать группами вкладок. Требуется манифест V3.
Chrome 89: Настраиваемые разрешения на доступные в Интернете ресурсы
Определения доступных ресурсов в Интернете в Manifest v3 изменились, чтобы расширить расширение доступа к ресурсам на основе идентификатора происхождения или расширения запрашивателя.
Сообщение в блоге: преобразователь расширения Manifest
Команда «Расширения Chrome» имеет открытый источник «преобразователь манифеста удлинения», инструмент Python, который автоматизирует некоторые из механических аспектов преобразования расширений в Manifest V3. Смотрите сообщение о объявлении в блоге и получите его от GitHub .
Chrome 88: Manifest V3 Общая доступность
Manifest V3 является основным обновлением платформы расширений; См . Обзор Manifest V3 для краткого изложения новых и измененных функций. Расширения могут продолжать использовать Manifest V2 на данный момент, но в ближайшем будущем это будет снято. Мы настоятельно рекомендуем вам использовать Manifest V3 для любых новых расширений, и как можно скорее начнем переносить существующие расширения, чтобы проявить V3.
,Проверьте эту страницу часто, чтобы узнать об изменениях в расширениях хрома, документации по расширениям или соответствующей политике или другим изменениям. Вы найдете другие уведомления, опубликованные в Google Group . График Chrome перечисляет стабильные и бета -даты.
Сообщение в блоге: новое меню расширений
В Google I/O Ou 2024 мы поделились некоторыми ранними проектами для предстоящих изменений в меню «Расширения», которые дают пользователям больше контроля над расширениями сайтов. Мы собираемся начать тестирование этих изменений в ближайшее время, начиная с небольшого процента пользователей в Канарских островах и с надеждой развернуть их более широко в будущем.
Мы также представляем chrome.permissions.addHostAccessRequest()
API.
Читайте больше в нашем сообщении в блоге .
Chrome 132: новое замороженное свойство в API в таблицах
Начиная с хрома 132, frozen
свойство в API вкладок указывает, была ли вкладка заморожена браузером. Сообщения, отправленные на замороженные вкладки, будут направлены в очередь и обрабатываются, когда вкладка не является незамеренной.
Быстрый API в расширении хрома
Приглашенный API для расширений теперь доступен в испытании происхождения, поэтому вы можете создавать хромированные расширения, которые используют Gemini Nano, нашу наиболее эффективную языковую модель в браузере.
Присоединяйтесь к быстрому испытанию API Origin, работающего в Chrome 131-136, и поделитесь своими отзывами. Ваш вход может напрямую повлиять на то, как мы создаем и реализуем будущие версии этого API, и все встроенные API AI.
Сообщение в блоге: Что происходит в расширениях Chrome, октябрь 2024 г.
Пришло время для очередного собрания того, что происходит в расширениях Chrome: у нас есть захватывающие обновления интеграции искусственного интеллекта, новых API, событий и видео. Прочитайте все об этом в том, что происходит в Chrome Advensions Octoble Edition !
Присоединяйтесь к встроенному испытанию AI
Chrome запустил встроенный AI Challenge: вам предложено создать инновационные веб-приложения и расширения Chrome, используя интегрированные модели ИИ Chrome и API , и у вас есть шанс выиграть призы, которые составляют 65 000 долларов США.
Зарегистрируйтесь и получите больше информации на встроенном веб-сайте AI Challenge . Мы не можем дождаться, чтобы увидеть, что вы создаете, когда внедряете Интернет с ИИ!
Chrome 130: Action.onusersettingschanged
Начиная с Chrome 130, событие Action.onusersettingSchanged доступно. Это следует за предложением в общественной группе Webextensions. Спасибо Microsoft за вклад в Chromium.
Chrome 130: Storagearea.getKeys ()
Начиная с Chrome 130, метод getKeys () доступен на интерфейсе Storagearea, используемом chrome.storage
API. Это следует за предложением в общественной группе Webextensions.
Chrome 128: Сопоставление заголовка ответа в декларативном чистом запросе
Начиная с Chrome 128, мы добавляем поддержку для сопоставления заголовков ответов в API декларативного чистого запроса. Это был общий запрос, особенно для сопоставления заголовка типа контента, и мы разработали подходящий API вместе с группой сообщества Webextensions.
Мы обновили нашу ссылку API, чтобы включить новые responseHeaders
и excludedResponseHeaders
. Вы можете использовать их, чтобы проверить наличие и значение данного заголовка.
В рамках этого обновления мы добавили в нашу документацию новый раздел оценки правил , который объясняет, как соответствуют правила. В частности, для сопоставления заголовков правила могут работать только после получения заголовков ответов, поэтому они применяются на более позднем этапе, чем другие правила. Это означает, что запрос достигает сервера, прежде чем заблокирован или перенаправлен.
Видео: Что такое сценарии контента?
Узнайте о сценариях контента в расширениях Chrome, в том числе о том, как зарегистрировать CSS и JavaScript для запуска на конкретной странице. Проверьте полное видео .
Важные обновления политики
Команда Chrome Web Store опубликовала серию обновлений на странице политик программ разработчиков, предназначенной для стимулирования разработки высококачественных продуктов, предотвращения обманчивого поведения и обеспечения информированного согласия пользователя. Ребекка Соарес, менеджер по политикам веб -магазина Chrome, суммировала все обновления в расширениях Chrome: Важные обновления политики в блоге .
Сообщение в блоге: Что происходит в расширениях Chrome, июль 2024 г.
За последние три месяца мы развернули несколько значительных обновлений и новых функций, в том числе начало манифеста V2 Phase Out. Встаньте на скорость в том, что происходит в Chrome Advensions Julal Edition !
Видео: Что такое дистанционный хост -код?
Патрик из команды Chrome Extensions объясняет концепцию дистанционно размещенного кода (RHC) в расширениях Chrome. Узнайте, почему RHC больше не разрешена, как его обнаружить и что делать, если ваше расширение должно быть обновлено. Проверьте полное видео .
Chrome 127: Новое действие. API Openpopup
Начиная с Chrome 127, action.openPopup
API доступен для всех расширений. Раньше он был доступен только в Канарейке или для расширений, установленных политикой.
Видео: Интервью команды доверия и безопасности
Команда Devrel Devrels Chrome села с командой Trust & Safety, которая ведет обзор в веб -магазине Chrome, чтобы задать ваши вопросы. Проверьте полное видео .
Сообщение в блоге: начинается манифест v2.
Начиная с 3 июня на Chrome Beta, Dev и Canary каналах, если пользователи по -прежнему имеют установленные растяжения V2, некоторые начнут видеть баннер предупреждения при посещении их страницы управления расширением - Chrome: // Расширения - информируя их, что некоторые (манифест V2) расширения, которые они установили, скоро не будут поддерживать. Узнайте больше в официальном объявлении
Обновления для пользовательского интерфейса боковой панели
Недавно мы внесли некоторые изменения в пользовательский интерфейс боковой панели, в том числе добавление значка PIN -кода и удаление значка Global Side Panel. Читайте больше в PSA и посмотрите нашу обновленную документацию и образцы .
Сообщение в блоге: расширения Chrome в Google I/O OC 2024
Еще один Google I/O -вывод стоит позади, и мы рассмотрели все захватывающие обновления расширений! Отправляйтесь на YouTube, чтобы посмотреть полное видео и прочитать наш пост в блоге для некоторых основных моментов.
Пропустить обзор для подходящих декларативных изменений в чистом запросе
В веб -магазине Chrome теперь позволяет пропустить обзор для подходящих изменений при использовании API декларативного чистого запроса. Узнайте больше о праве на участие и о том, как зарегистрироваться в документации Chrome Web Store .
DeployperCentage доступен в API Chrome Web Store
Недавно мы обновили нашу документацию по API Web Store Chrome, чтобы включить информацию о deployPercentage
, которая позволяет вам назначить процент от частичного развертывания развертывания. Узнайте о deployPercentage
.
Chrome 126: Испытания происхождения в расширениях
Chrome 126 представляет новый Manifest.json Field - trial_tokens
, позволяя вам выбрать испытания происхождения и испытания по терапии на всех поверхностях расширения. Прочитайте руководство для получения дополнительной информации.
Сообщение в блоге: Что происходит в Chrome Adensions-April 2024
Мы опубликовали новое издание того , что происходит в расширениях Chrome . В сообщении обсуждается, над чем работала команда расширения в течение последних нескольких месяцев. Это включает в себя: version rowlback в веб -магазине Chrome, лучшая поддержка Auth Base Auth и другие запуска API и обновления.
Версия откаты в приборной панели разработчика Chrome Web Store Developer
Обратите свое расширение на предыдущую опубликованную версию в веб -магазине Chrome - без дополнительного обзора! Прочитайте сообщение в блоге и документацию для получения дополнительной информации.
Chrome 124: Advanced Documentscan API
An advanced documentScan
API is now available on ChromeOS to discover and retrieve images from attached document scanners.
Chrome 124: поддержка WebGPU в обслуживании работников
Со времен Chrome 124 работники обслуживания поддерживают WebGPU . Для быстрого запуска проверьте образец расширения WebGPU .
Chrome 123: API событий поддерживает фильтрацию с помощью блоков CIDR
API событий теперь поддерживает фильтрацию с помощью бесклассовых междоменных блоков маршрутизации (CIDR). Блок CIDR - это набор IP -адресов, которые разделяют префикс сети и одинаковое количество битов. Ранее разработчик нуждался в фильтровании нескольких IP -адресов, необходимых для настройки правила фильтра для каждого из адресов в диапазоне блоков. Теперь, когда расширение вызывает addListener()
, принятое правило означает, что обработчик событий будет вызван только тогда, когда хост часть URL -адреса является IP -адресом и содержится в любом из блоков CIDR, указанных в массиве.
Chrome Web Store: обновления требований к имени расширения
В веб -магазине Chrome в настоящее время существует универсальный предел 75 символов для поля "name"
расширения в Manifest.json. Ранее предел английского был 45 символов, и не было никаких ограничений в поле "name"
в других местах.
Первоначально это было предназначено для того, чтобы разрешить культурные и языковые различия, которые не могут быть захвачены в одинаковом количестве символов. К сожалению, эта функция подвергалось насилию со стороны небольшого числа разработчиков, чтобы спамить магазин. В результате мы вводим новый универсальный предел, увеличение до 75 символов. Этот предел сегодня охватывает почти все расширения в магазине, поэтому в результате этого изменения вам, вероятно, это не потребуется никаких действий. Если вы попытаетесь загрузить расширение, которое имеет имя дольше, чем максимальный предел, то загрузка будет заблокирована магазином.
Пост в блоге: Путешествие Eyeso to Testing Service Worker Supply
В этом посте команде Extension Engine Engine мы исследуем проблему тестирования работников службы расширения. В Manifest v2 расширения жили на фоновой странице, которая бодрствовала на протяжении всего жизненного цикла расширения. Вместо этого Manifest V3 использует работников обслуживания, а обслуживание, по проекту, сохраняет ресурс, отключившись, когда они не нужны. Это представляет определенные проблемы тестирования. Этот пост объясняет, как Eyeo решал эти проблемы .
Chrome 123: Слова теперь работает, когда устройство спит
Аварийные сигналы, установленные с использованием API API chrome.alarms
, больше не задерживаются, когда устройство ложится спать. Когда устройство просыпается, тревога будет стрелять один раз, независимо от того, сколько тревоги было пропущено. Например, скажем, что сигнализирует один раз в час, и устройство, на котором он находится, спит с 12:55 до 2:05, а затем только 2:00 утра запускает событие onAlarm
. Он будет стрелять как можно ближе к 2:00 утра, и сразу же, когда устройство просыпается, если оно спало.
Это изменение вносит Chrome в соответствии с согласованным поведением в группе сообщества Web Adensions.
Сообщение в блоге: изменения в поведении BFCache с портами сообщений расширения
Back/Forward Cache (BFCACHE) - это оптимизация браузера, которая позволяет мгновенно навигацию назад и вперед. Начиная с Chrome 123, когда в BFCache хранится страница с открытым расширением, канал сообщения закрыт, что означает, что на эту страницу не будет отправлено никаких сообщений. Следовательно, сценарии расширения должны прослушать события жизненного цикла, такие как onDisconnect
, и настроить новое соединение, когда страница восстанавливается из BFCache.
Для получения дополнительной информации и примера кода см. Изменения в поведении BFCache с портами сообщений о расширении .
Chrome 122: Обещающая поддержка по асинхронному расширению API
Мы закончили внедрение поддержки перспективной поддержки для всех асинхронных методов API расширения. Это было сделано для модернизации методов API путем улучшения эргономики работы с асинхронными операциями. Горстка методов (например, desktopCapture.chooseDesktopMedia()
) продолжает поддерживать только обратные вызовы, потому что их текущие поверхности не совместимы с обещаниями. Для обратной совместимости вызовы все еще поддерживаются. Если вы найдете обещание, которое не удается, подайте ошибку .
Новое руководство по общению в режиме реального времени
Мы только что опубликовали гиды по вариантам в режиме реального времени в расширениях. Обновления в режиме реального времени обеспечивают мгновенный путь связи с ваших серверов непосредственно до установки расширения. Кроме того, у нас есть новое руководство по использованию Chrome.gcm , Web Push .
Новое руководство и пример: увольнение работников тестирования
Мы только что опубликовали руководство о том, как протестировать прекращение службы с кукловым . Сопровождающий образец демонстрирует это в кукловом и селене.
Обновленная образец для собственных сообщений
Мы только что опубликовали обновленную образец для обмена сообщениями. Этот API позволяет вашему расширению начинать и общаться с другим приложением. Спасибо участнику Github Shubham-Rasal за работу по этому поводу.
Chrome 121: новое самостоятельное свойство на tabs.tab
Новое свойство, названное lastAccessed
было добавлено в объект tabs.Tab
. Это свойство указывает, когда вкладка была в последний раз активирована. Возвращенное значение находится в миллисекундах с эпохи.
Chrome 121: Неподдерживаемые «фоновые» ключи теперь выпускайте предупреждение
В переключении от Manifest V2 на Manifest V3 дети "background"
манифеста были изменены, чтобы приспособить замену фоновых сценариев на работников службы расширения. Раньше, добавление манифестных клавиш V2 "scripts"
, "page"
или "persistent"
к ключу "background"
из манифестного расширения v3 принесло бы ошибку. Присутствие этих ключей теперь вызывает предупреждение.
Это делается для того, чтобы включить использование одного манифестного файла в расширениях в нескольких браузерах, согласно предложению в группе сообщества .
Chrome 120: Минимальная гранулярность тревоги уменьшена до 30 секунд
Начиная с Chrome 120, растяжения Manifest V3 могут использовать chrome.alarms
API Alarms с задержками или периодами 30 секунд, а не требует значений 60 секунд или более.
Сообщение в блоге: возобновление перехода к Manifest V3
Срок службы поддержки Manifest V2 была обновлена. Смотрите наш пост в блоге в ноябре 2023 года для получения подробной информации.
Сообщение в блоге: улучшения поддержки фильтрации контента в Manifest v3
Узнайте о том, как мы улучшили API DeclarativenetRequest в нашем новом сообщении в блоге .
Сообщение в блоге: что нового в Chrome 120 для расширений
Chrome 120 Beta была недавно выпущена. Для краткого изложения важных обновлений, имеющих отношение к разработчикам расширения, прочитайте наш новый пост в блоге: Что нового в Chrome 120 для расширений . Этот релиз также отмечает основную веху, поскольку он удаляет два последних элемента (пользователи, обработчики файлов на Chromeos) из списка критических пробелов на платформе .
PSA: Изменение URL -адреса политики в области политики конфиденциальности в приборной панели разработчика
Политики конфиденциальности на приборной панели разработчика теперь добавляются на уровне элементов. Это позволяет вам предоставлять другую политику конфиденциальности на предмет. Узнайте больше об этом изменении в нашем PSA .
Видео: чат с Мэттом Фрисби
Мы только что опубликовали новое видео на Chrome для разработчиков на канале YouTube в чате с экспертом по разработчику Google и автором Мэттом Фрисби. Смотрите это здесь .
Новое руководство по расширениям тестирования
Мы только что опубликовали новое руководство о том, как написать автоматические тесты для расширений, в том числе «Как писать модульные тесты» , а также общее руководство , а также учебное пособие по сквозным тестированию.
Сообщение в блоге: Что происходит в расширениях Chrome - октябрь 2023 г.
Мы только что опубликовали второе издание того, что происходит в расширениях Chrome . В сообщении обсуждается, над чем работала команда по расширению в течение последних нескольких месяцев, включая решение проблем стабильности работников обслуживания, и добиться хорошего прогресса в закрытии всех пробелов платформы MV3. Мы также делимся захватывающими предстоящими выпусками API, такими как API списка чтения и API пользовательских сценариев.
Повышенные ограничения набора статических правил в декларативном чистом запросе API
Следуя обратной связи в группе сообщества Web Extensions, мы значительно увеличиваем предел включенных статических наборов статических правил с 10 до 50. Кроме того, мы увеличиваем общее количество разрешенных статических наборов правил с 50 до 100. Это в настоящее время доступно в Канарии.
Улучшенное руководство по коду с дистанционным домом
Требование для Manifest V3 заключается в том, что расширения могут больше не использовать код с дистанционным размером. Хотя это было частью нашего руководства по миграции с самого начала, мы подумали, что стоит улучшить руководство по этому вопросу. Эта страница теперь предоставляет больше информации, описывающая то, что все еще возможно в Manifest V3, и предоставляя больше информации о стратегиях для обновления.
Существует связанное дополнение к нарушениям устранения неисправностей Chrome Web Store . В новом разделе описываются общие причины, по которым расширения с дистанционным кодом отклоняются.
Chrome 118: IsurlfilterCasasesEnsity теперь по умолчанию ложно
Начиная с Chrome 118, isUrlFilterCaseSensitive
Property в Chrome.declarativenetRequest API было изменено, чтобы по умолчанию на false
. Если вы хотите сохранить старое поведение, вы можете явно установить isUrlFilterCaseSensitive
к true
в ваших правилах DeclarativeIneTrequest.
Это следует за дискуссиями в группе сообщества Web Adensions. Firefox и Safari уже внесли аналогичное изменение.
Документация по файлам cookie и веб -хранилище
We published a new guide on how cookies and web storage APIs work in Chrome extensions . It includes details on cookie and storage partitioning changes in Privacy Sandbox , an ongoing project to deprecate third-party cookies through the creation of a series of new web platform APIs, and details on how they work in extensions.
Extension samples now searchable
We recently created a page that lets you search Chrome extension samples . The search page has multiple options. A search box lets you search for text in sample titles. You can restrict the search by permission or extension API. An additional filter lets you restrict search to either API or functional (use case) samples.
This new sample page was built by a Google Summer of Code participant, Xuezhou Dai, who also contributed several new samples. You can read about their experiences this past summer in their post on our blog .
As before, our code samples are still available on GitHub for cloning or forking.
Chrome 118: Changes to opening file: scheme URLs
Beginning in Chrome 118, extensions will need the "Allow access to file URLs" setting enabled from the chrome://extensions
page to open file:// scheme URLs using the Tabs or Windows APIs. You can programmatically check for this access by calling chrome.extension.isAllowedFileSchemeAccess()
. Firefox already restricts file URLs, and Safari supports the change. For more information, read the post in the extensions Google Group .
Chrome 117: Expanded URL protections on extension API navigations
Previously navigation triggered from extension API calls for tabs.update()
, tabs.create()
, and windows.create()
emitted an error for some chrome:// URLs. Additionally, calling tabs.update()
with a JavaScript URL was forbidden. In 117, these protections on JavaScript URLs have been expanded to the tabs.create()
method and a number of additional chrome:// URLs have been added to the list of forbidden URLs that applies to all of the previously mentioned methods.
Improved guidance for the declarativeNetRequest API
The chrome.declarativeNetRequest
API blocks or modifies network requests by specifying declarative rules. This lets extensions modify network requests without intercepting them and viewing their content, thus providing more privacy to users. It's also tricky to use. With that in mind, we've rewritten the guidance in a way that we think paints a clearer picture of how to implement declarative rulesets. Read the new section at the link above.
Using your Google Analytics account with the Chrome Web Store
The Chrome Web Store offers integration with Google Analytics, which allows you to see analytics for your Chrome Web Store listing in addition to the view offered in the Developer Dashboard. For more information, read Using your Google Analytics account with the Chrome Web Store .
Chrome 115: DevTools steps over content scripts by default
Injected content scripts are now in the DevTools ignore list by default. This doesn't affect breakpoints, but it does mean that content scripts will be stepped over during debugging and exceptions from these scripts will be ignored. When a content script is open in the Sources tab, a banner alerts you if this is on and provides an option to remove your content script from the ignore list. To turn this behavior off, open DevTools, go to Settings then Ignore list . To learn more, see What's new in DevTools .
Chrome 116 beta: More than we can fit here
Chrome 116 is a big release for extensions. You can now open side panels programmatically. A new method lets you learn if there's an active offscreen document. Service workers got serveral improvements. There's enough improvements in 116 that we've written a blog post to cover them . Chrome 116 is in beta as of July 19.
Blog post: What's happening in Chrome Extensions
We've just published an overview of this year's changes and improvements to extensions . The post discusses the year's big new features, including the Side Panel API, service worker enhancements, and offscreen documents. You'll also get a peek at what we're working on for this quarter. The article lists much more, with links to all.
New guidance and sample: Learn how to use Google Analytics 4 in your Chrome extension
We published new Google Analytics and geolocation guidance and samples:
- An updated version of our Google Analytics guidance explaining how you can use Google Analytics 4 in your Chrome extension. We've also added a working Google Analytics 4 sample to our Github sample repository. Check out
google-analytics.js
for the relevant code related to Google Analytics. - A new Geolocation guide and three samples demonstrating how to access geolocation in service workers, content scripts, popups and side panels.
Chrome 115: Specify multiple reasons in chrome.offscreen.createDocument()
You can now specify multiple reason
enums when calling chrome.offscreen.createDocument()
. Use this when an offscreen document will be used for multiple different purposes. The browser uses the supplied reasons to determine the lifetime of the offscreen document.
New tool: Extension Update Testing Tool
We've just released the Extension Update Testing Tool , a local extension update server that can be used for testing updates to Chrome Extensions during local development, including permission grants. The tool shows the user's update flow, including keeping an extension disabled until a user grants any newly requested permissions. This tool is particularly useful for simulating the permission changes requested when updating an extension from Manifest V2 to Manifest V3.
Chrome 114: New Side Panel API
Introducing the new Side Panel API, a companion surface that allows users to access tools alongside the content they are browsing. To learn more, visit the Side Panel API reference . Additionally, we've added many side panel samples to our GitHub sample repository . We also share more about side panels in the new blog post Designing a Superior User Experience with the New Side Panel API . Our quality guidelines policy and best practices have also been reviewed to provide further guidance on creating high-quality side panel extensions.
Your feedback is important in crafting this API; please share your thoughts and feature requests in the chromium-groups . Stay tuned for new updates as we continue to enhance the Side Panel API.
New Samples: WASM in extensions
There are two new samples available that demonstrate how to use WASM in an extension:
- Using WASM in Manifest V3 shows the general method for including a WASM module.
- Using WASM as a module in Manifest V3 shows how to use it in a module.
Special thanks to GitHub contributor @daidr for these samples.
Updated Manifest V3 migration guidance
We've updated the Known Issues section of our Manifest V3 migration guidance with an updated list of extension platform gaps that we intend to close before announcing a new Manifest V2 deprecation timeline.
Recording audio and video with Manifest V3
We've just published a new article called Audio recording and screen capture , which covers recording audio or video from a tab, window, or screen in Manifest V3. This article describes multiple approaches to recording involving the chrome.tabCapture
API and the getDisplayMedia()
function.
Chrome 114: Increased storage.local quota
We have increased the quota for the storage.local
property to approximately 10 MB. This was agreed to in the Web Extensions Community Group . This brings storage.local
in line with storage.session
which was changed in Chrome 112.
New extension service worker tutorial and help
Service Workers are an integral part of Chrome Extensions. We just published a tutorial explaining the basics of registering, debugging, and interacting with Service Workers. We've also added a new Service worker guide explaining important concepts in more detail. We'll be expanding this section in the coming months.
More troubleshooting tips for Web Store violations
To help with Chrome Web Store publishing, we added new guidance in two areas. Guidance for minimum functionality centers around providing users with benefits and enriching their browsing experience. Guidance for affiliate ads is about making users are aware of extensions using affiliate links or codes for monetization, and giving them some amount of control by requiring user action before inclusion.
New instructions for the Extension Manifest Converter
We've rewritten the README for the Extension Manifest Converter to make it easier to see what you need to do after running the tool. The converter helps helps migrate extensions built on Manifest V2 to Manifest V3. The new README describes what the tool does using words that closely match those in the migration guide's checklist . The converter doesn't do everything, but it does eliminate many tasks that don't require a human judgement call.
Chrome 113: New reasons for offscreen documents
We have added two new reason types to the Offscreen Documents API. Use LOCAL_STORAGE
to access the web platform's localStorage API. Use WORKER
when creating web workers.
Google Analytics 4 now in the Developer Dashboard
The Chrome Web Store Developer Dashboard now supports Google Analytics 4 (GA4). We've simplified setting up Google Analytics and made access management for group publishers more straightforward. If you previously used Google Universal Analytics to track your store listing activity, you will need to take action by July 1, 2023 to ensure that you continue receiving data about your store listing. For more information, see the post on the Chromium Extensions Google Group .
The File Handling API comes to ChromeOS
The File Handler API is available for experimentation on ChromeOS in Canary for versions 112 and 113. It lets extensions on ChromeOS open files with specified MIME types and file extensions. To implement file handling add a set of rules to the manifest.json
. This feature works the same as for Progressive web apps. For more information, see the article elsewhere on this site.
To enable file handling:
- Starting in 112, launch Chrome using the
--enable-features=ExtensionWebFileHandlers
flag, starting in 112 - Starting in 113, paste
os://flags/#extension-web-file-handlers
into the Chrome omnibox and select 'Enabled' from the dropdown menu.
We hope to launch this feature in Chrome 115, in late June. Watch this space for updates.
New Samples: dynamic declarations and programmatic injection
We've built a new sample for the chrome.scripting
API. It demonstrates dynamic declarations, where a content script is registered at runtime, and programmatic injection, where a script is executed in a tab that is already open.
New Samples: Declarative Net Request use cases
Three new samples are available demonstrating the Declarative Net Request API . Each demonstrates implementation of a single use case. The first shows how to block cookies. The remaining two demonstrate blocking and redirecting URLs.
Chrome 112: Increased storage.session quota
From Chrome 112, the quota for the storage.session
property has been increased to approximately 10 MB. This was agreed to in the Web Extensions Community Group: https://github.com/w3c/webextensions/issues/350
Chrome 109: Offscreen documents
Offscreen documents are now available in Manifest V3 extensions. These help with the transition from background pages to extension service workers by providing support for DOM-related features and APIs. For more information, read the blog post .
Chrome 110: Is an extension enabled
The chrome.action.isEnabled()
method programmatically checks whether an extension has been enabled for a specific tab. This saves you from maintaining the enabled state of your tabs. This new method takes a tab ID and a reference to a callback and returns a boolean. It has one limitation: tabs created using chrome.declarativeContent
always return false.
(The chrome.action
namespace recently got new methods for controlling the appearance of extension badges. For more information, see Setting badge colors .)
Chrome 110: Change in service worker idle timeout
Previously, an extension service worker would frequently shut down at the five minute mark. We've changed this behavior to more closely resemble service worker lifetime's on the web. An extension service worker will be shut down after either thirty seconds of inactivity or if a single activity takes longer than 5 minutes to process. For more information, see Longer extension service worker lifetimes .
Post: Pausing Manifest V2 phase-out
The Manifest V2 deprecation timelines are under review and the experiments scheduled for early 2023 are being postponed. For more information, read the update in the chromium-extensions Google Group.
Chrome 110: Setting badge colors
The chrome.action
namespace has two new methods to give you more control over the appearance extension badges. The setBadgeTextColor()
and getBadgeTextColor()
methods allow an extension to change and query its toolbar icon's badge text color. When used with setBadgeBackgroundColor
and getBadgeBackgroundColor
these new methods let you enforce design and brand consistency.
Blog post: More details on the transition to Manifest V3
We have clarified the Manifest V2 deprecation timeline . The Manifest V2 support timeline has also been updated to reflect this information.
Docs update: Known issues when migrating to Manifest V3
We've put together a list of major features currently in development and open bugs . Our goal with this page is to help developers better understand the current state of the platform and what features they can target as they prepare for the future.
Chrome Web Store: "large promo tile" image upload removed
Chrome Web Store has removed the "large promo tile" upload UI from the item Store Listing tab in the developer dashboard. This change does not affect the end user experience as these images were not used in the consumer UI. See this chromium-extensions post for additional details.
Chrome 106: Allow pages on file:// urls to access web accessible resources
Opaque origins such as sandboxed iframes and dynamic import should also be able to access web accessible resources, according to crbug.com/1219825#c11 .
Chrome 106: Fixed bug allowing incorrect final arguments on some async API functions
Previously, Manifest V3 calling async APIs could provide an invalid final argument and Chrome would not error. With this fix Chrome will now correctly error and report that there was no matching signature. Developers are encouraged to check their extensions on Canary for any errors in case they accidentally using incorrect signature for an API call that will be broken by this bug fix.
Blog post: Chrome Web Store analytics revamp
Chrome Web Store has a revamped item analytics experience for the Chrome Web Store Developer Dashboard. The new dashboard is easier to understand at a glance and consolidates the most useful information up front. Read the blog post for more information.
Chrome 105: promises for the Identity API
Functions on the Identity API now support promise based calls. This comes with a slight change to the surface for identity.getAuthToken()
, where the asynchronous return set to a promise based call will have "token" and "grantedScopes" as parameters on a single object (as opposed to the callback version receiving them as separate arguments to the callback).
Chrome 104: New favicons API for Manifest V3
Manifest V3 extensions can now access favicons using a new URL pattern: chrome-extension://<id>/_favicon/
, wherechrome://favicons
API. See the Favicon API docs for more information.
Docs update: Developer trader/non-trader disclosure
Added the trader/non-trader developer identification that informs developers to accurately self-declare their trader/non-trader status.
Chrome 103: Wasm in Manifest V3 requires wasm-unsafe-eval
Chrome no longer grants extensions script-src: wasm-unsafe-eval
by default. Extensions that use WebAssembly must now explicitly add this directive and value to extension_pages
in their content_security_policy
declarations.
Chrome 103: Changing MV3 shortcuts take effect immediately
When changing a Manifest V3 extension's keyboard shortcut on chrome://extensions/shortcuts
, updates are now applied immediately. Previously the extension would have to be reloaded before the change would take effect.
Chrome 102: Dynamic content scripts in main world
Dynamically registered content scripts can now specify the world that assets will be injected into. See scripting.registerContentScripts()
for details.
Chrome 102: New manifest field "optional_host_permissions"
Manifest V3 extensions can now specify the optional_host_permissions
key in manifest.json. This allows Manifest V3 extensions to declare optional match patterns for hosts just as Manifest V2 extensions could using the optional_permissions
key.
Chrome 102: injectImmediately property in scripting.executeScript()
chrome.scripting.executeScript()
now accepts an optional injectImmediately
property on it's injection
argument. If present and set to true, the script will inject into the target as soon as possible, rather than waiting for document_idle
. Note that this is not a guarantee the script will inject before the page is loaded since the page continues to load while the API call is being made.
Chrome 102: Omnibox API support in Manifest V3
The Omnibox API can now be used in service worker-based extensions. Previously, some of this API's methods would throw on invocation due to internal dependencies on DOM capabilities.
Chrome 102: wasm-unsafe-eval allowed in Manifest V3 CSP
Manifest V3 extensions can now include wasm-unsafe-eval
in their content_security_policy
declarations. This change allows Manifest V3 extensions to use WebAssembly.
Chrome 102: New storage.session API
Manifest V3 extensions can now use in memory storage storage.session .
Docs update: Chrome Web Store item discovery
Discovery on Chrome Web Store gives an overview of how users find items on the Chrome Web Store and how our editors select items to feature.
Chrome 101: Improved declarativeNetRequest domain conditions
declarativeNetRequest rule conditions have been updated to allow extensions to better target requests based on the request's "request" and "initiator" domains. The relevant condition properties are initiatorDomains
, excludedInitiatorDomains
, requestDomains
, and excludedRequestDomains
. See also this chromium-extensions thread .
Chrome 100: Resolved issue with scripting.executeScript() on newly created tabs
Fixed a longstanding issue where calling scripting.executeScript()
on a newly created tab or window could fail.
Chrome 100: native messaging port keeps service worker alive
Connecting to a native messaging host using chrome.runtime.connectNative()
in an extension's service worker should keep the service worker alive as long as the port is open.
Chrome 100: omnibox.setDefaultSuggestion() supports promises and callbacks
The omnibox.setDefaultSuggestion()
method now returns a promise or accepts a callback to allow developers to determine when the suggestion has been properly set.
Chrome 100: i18n.getMessage() support in extension service workers
The chrome.i18n.getMessage()
API is now supported in extension service worker contexts.
Chrome 99: match_origin_as_fallback in Canary
Content scripts can now specify the match_origin_as_fallback
key to inject into frames that are related to a matching frame, including frames with about:
, data:
, blob:
, and filesystem:
URLs. See the content scripts documentation for details.
Chrome 99: extension service worker support for file: schemes in Canary
Service worker-based Manifest V2 and Manifest V3 extensions can now use the Fetch API to request file:
-scheme URLs. Access to file:
-scheme URLs still requires that the user enable 'Allow access to File URLs' for the extension in the chrome://extensions
page.
Chrome 99: promise support for messaging APIs in Canary
Promise support has been added to tabs.sendMessage
, runtime.sendMessage
, and runtime.sendNativeMessage
for extensions built for Manifest V3.
Docs update: Chrome Web Store review documentation
Added a new reference page that provides an overview of the Chrome Web Store review process and explains how developer program policy enforcement is handled.
Chrome 98: scripting.executeScript() and scripting.insertCSS() accept multiple files
The Scripting API's executeScript()
and insertCSS()
methods now accept multiple files. Previously these methods required an array with a single file entry.
Docs update: review violation troubleshooting updates
The Troubleshooting Chrome Web Store violations page has been updated to provide developers with more detailed guidance for common reasons for rejection.
Chrome 96: expanded promise support to 27 more APIs
This release contains significantly more promise updates than any previous release. Updates include both general and ChromeOS-specific extensions APIs. Expand the following sections for details.
Extensions APIs
A number of APIs now support promises in Manifest V3.
-
chrome.browsingData
-
chrome.commands
-
chrome.contentSettings
-
chrome.debugger
-
chrome.downloads
-
chrome.enterprise.hardwarePlatform
-
chrome.fontSettings
-
chrome.history
-
chrome.instanceID
-
chrome.permissions
-
chrome.processes
-
chrome.search
-
chrome.sessions
-
chrome.topSites
Also, APIs that use the ChromeSetting
prototype now also support promises. The following APIs are affected by this change.
ChromeOS APIs
-
chrome.certificateProvider
-
chrome.documentScan
-
chrome.enterprise.deviceAttributes
-
chrome.enterprise.networkingAttributes
-
chrome.fileBrowserHandler
-
chrome.fileSystemProvider
-
chrome.loginState
-
chrome.printingMetrics
-
chrome.wallpaper
Chrome 96: dynamic content scripts
The chrome.scripting
API now supports registering , updating , unregistering , and getting a list of content scripts at runtime. Previously, content scripts could only be statically declared in an extension's manifest.json or programmatically injected at runtime with chrome.scripting.executeScript()
.
Docs update: Manifest V2 support timeline
The Manifest V2 to V3 transition timeline was announced in this blog post and a more detailed timeline page was published.
Chrome 96: declarativeNetRequestWithHostAccess permission
The new declarativeNetRequestWithHostAccess
permission allows extensions to use the chrome.declarativeNetRequest
API on sites the extension has host permissions for. This also enables existing Manifest V2 extensions that use webRequest
, webRequestBlocking
, and site-specific host permission to migrate to the chrome.declarativeNetRequest
API without requiring the user to approve new permissions.
Chrome 95: inject scripts directly into pages
The chrome.scripting
API's executeScript()
method can now inject scripts directly into a page's main world. Previously, extensions could only inject directly into the extension's isolated world. For more information on isolated worlds, see the documentation on content scripts .
Chrome 95: promise support for Storage API
Methods on the Manifest V3 version of the chrome.storage
API now return promises.
Policy update: two step verification enforcement
The policy update blog post published on June 29, 2021 has been updated to correct the two step verification deployment timeline.
Chrome 94: declarative net request static ruleset changes
The chrome.declarativeNetRequest
now supports specifying up to 50 static rulesets ( MAX_NUMBER_OF_STATIC_RULESETS ) and enabling up to 10 rulesets ( MAX_NUMBER_OF_ENABLED_STATIC_RULESETS ) at a time.
Chrome 93: cross origin isolation support
Both Manifest V2 and Manifest V3 extensions can now opt into cross origin isolation . This feature limits which cross-origin resources can load an extension's pages and enables the use of low level web platform features like SharedArrayBuffer
. Opt in will be required starting in Chrome 95.
Policy update: developer program policies updated
The Chrome Web Store Developer Program Policies have been updated with clarifications to the deceptive installation tactics, spam, and repetitive content policies. This update also includes a new two step verification requirement to publish on the Chrome Web Store. Read the blog post for more information.
Blog post: extension actions in Manifest V3
Chrome extensions had chrome.browserAction
and chrome.pageActions
APIs for years, but Manifest V3 replaced both with a generic chrome.actions
API. This post explores the history of these APIs and what has changed in Manifest V3. Read the post .
Blog post: introducing chrome.scripting
The chrome.scripting
API is a new Manifest V3 API focused on, well, scripting. In this post we dig into the motivations for this change and take a closer look at it's new capabilities. Read the post .
Chrome 92: module service worker support
Chrome now supports JavaScript modules in service workers. To specify a module a module in your manifest:
"background": {
"service_worker": "script.js",
"type": "module"
}
This loads the worker script as an ES module, which lets you use the import
keyword in the worker's script to import other modules.
Chrome 91: chrome.action.getUserSettings()
The new chrome.action.getUserSettings()
method allows extensions to determine if the user has pinned the extension to the main toolbar.
Chrome 90: chrome.scripting.removeCSS()
The new chrome.scripting.removeCSS()
method allows extensions to remove CSS that was previously inserted via chrome.scripting.insertCSS()
. It replaces chrome.tabs.removeCSS()
.
Chrome 90: returning promises from scripting.executeScript()
chrome.scripting.executeScript()
now supports returning promises. If the resulting value of the script execution is a promise, Chrome will wait for the promise to settle and return its resulting value.
Chrome 90: chrome.scripting.executeScript() results include frameId
Results returned from chrome.scripting.executeScript()
now include the frameId . The frameId
property indicates the frame that the result is from, letting extensions easily associate results with the individual frames when injecting in multiple frames.
Chrome 89: new API for managing tab groups
The new chrome.tabGroups
API and new capabilities in chrome.tabs
let extensions read and manipulate tab groups. Requires Manifest V3.
Chrome 89: customizable permissions for web accessible resources
Web accessible resources definitions in Manifest V3 have changed to let extensions restrict resource access based on the requester's origin or extension ID.
Blog post: Extension Manifest Converter
The Chrome Extensions team has open sourced "Extension Manifest Converter", a Python tool that automates some of the mechanical aspects of converting extensions to Manifest V3. See the announcement blog post and get it from GitHub .
Chrome 88: Manifest V3 general availability
Manifest V3 is a major update to the extensions platform; see Overview of Manifest V3 for a summary of new and changed features. Extensions may continue to use Manifest V2 for now, but this will be phased out in the near future. We strongly recommend that you use Manifest V3 for any new extensions, and begin migrating existing extensions to Manifest V3 as soon as possible.