Хобрук: Ваш путь к мастерству в программировании

TypeError: браузер не определен (обмен сообщениями веб-расширения)

Я пытаюсь связать сценарий моей веб-страницы с моим сценарием содержимого моего веб-расширения с помощью кода ниже

Сценарий веб-страницы

const browser = window.browser || window.chrome;
browser.runtime.sendMessage(message,
     function (response) {
          console.log(response);
     }
);

Однако я продолжаю получать ошибку TypeError: browser is undefined. То же самое происходит, если вместо этого я использую chrome.runtime.sendMessage().

Как я должен использовать этот метод?


  • Вы можете использовать стандартный обмен сообщениями DOM через CustomEvent между страницей и сценарием содержимого. Обратите внимание, что chrome.runtime доступен только для HTTPS-страниц в новом Chrome, см. crbug.com/835287. 16.05.2018
  • Но я хочу, чтобы расширение вернуло ответ на основе отправленного сообщения. Поскольку события не предназначены для возврата значения, как я могу это сделать? 17.05.2018
  • Но ты можешь. См. документацию и примеры для CustomEvent. 17.05.2018
  • (Конечно, вам придется отправить ответ в отдельном событии) 17.05.2018
  • Хорошо, попробуем это. Спасибо 17.05.2018

Ответы:


1

Проблема здесь в том, что сценарии пользователя/веб-страницы (непривилегированные сценарии) не имеют доступа к API JavaScript в целях безопасности, а browser, chrome являются частью API JavaScript, к которым могут получить доступ только привилегированные сценарии, такие как фоновые сценарии веб-расширения и сценарии контента ( опять же, скрипты содержимого не имеют доступа ко всем API-интерфейсам JavaScript). По сути, если вам нужно отправить данные из сценария веб-страницы в фоновый сценарий, CustomEvent следует использовать для отправки данных в сценарий контента, который действует как мост, а оттуда отправлять эти данные в фоновый сценарий с помощью browser.runtime.sendMessage. Пример кода PFB

window.onload = function(){
    document.dispatchEvent(new CustomEvent("myEvent",{
        detail:["Hello","World"]
    }));
}

контентскрипт.js

document.addEventListener("myEvent", function (event) {
browser.runtime.sendMessage({
    data: event.detail
});

фон.js

browser.runtime.onMessage.addListener(function (message) {
     data = message.data;
     // do stuff
});
22.05.2018
  • Есть ли у меня причина вызывать background.js (например, производительность) вместо выполнения действий в contentscript.js? 22.05.2018
  • Зависит от варианта использования, как упоминалось выше, сценарии содержимого не имеют доступа ко всем API-интерфейсам JavaScript. Дополнительную информацию можно найти [здесь] (developer.mozilla.org/en- США/Дополнения/WebExtensions/) 23.05.2018
  • Новые материалы

    Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
    каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

    Как настроить Selenium в проекте Angular
    Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

    Аргументы прогрессивного улучшения почти всегда упускают суть
    В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

    Введение в Джанго Фреймворк
    Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

    Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
    Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

    Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
    Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

    стройный-i18следующий
    Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..