google-chrome - Chrome 扩展 - 消息传递

标签 google-chrome google-chrome-extension chromium

我正在尝试获取选项页面上设置的信息以更改我的扩展程序的行为。

基本上,如果 OptionsPage 上的复选框设置为 true,则扩展程序运行,否则不运行。
出于测试目的,我在 background.html 上返回 true,但它仍然不起作用。

你们能帮帮我吗?谢谢!

注入(inject)页面的代码:

if(chrome.extension.sendRequest() == 'true')
    alert("checkbox set to true");
else
    alert("it is disabled");

背景.html
<script>
chrome.extension.onRequest.addListener(function(){
    return true;
    }
</script>

最佳答案

如果您有 options page并且您想与 background page 交流,你可以简单地做,chrome.extension.getBackgroundPage()

与后台页面通信的选项页面

options.html

var bkg = chrome.extension.getBackgroundPage()
bkg.startExtension();
bkg.stopExtension();

背景.html
function startExtension() {
  console.log('Starting Extension');
}

function stopExtension() {
  console.log('Stopping Extension');
}

与后台页面通信的内容脚本

当您提到“将代码注入(inject)页面”时,是指任何网站吗?如果是这样,您需要使用 content scriptMessage Passing .为此,您可以这样做。

content_script.js
chrome.extension.sendRequest({action:'start'}, function(response) {
  console.log('Start action sent');  
});

背景.html
function onRequest(request, sender, sendResponse) {
 if (request.action == 'start')
   startExtension()
 else if (request.action == 'stop')
   stopExtension()

 sendResponse({});
};
chrome.extension.onRequest.addListener(onRequest);

无论如何,message passing对于任何进入扩展的人来说都是一本好书。

关于google-chrome - Chrome 扩展 - 消息传递,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2998775/

相关文章:

javascript - HTML4 中的 Element.animate()

Android Chrome 的背景属性表现不佳

google-chrome - Chrome Devpanel 扩展与后台页面通信

javascript - Chrome 扩展程序无法加载 .json 文件

javascript - 如何正确关闭websocket

macos - Chromium : GN/Ninja - linking to OS X Framework via Build. gn 失败

linux - 恢复被 Chrome 自动删除的部分下载文件

python - Selenium Chrome 选项和功能

html - 为什么居中超链接图像左右两侧的空白区域是可点击的?

html - 在伪元素在 chrome 和 firefox 上出现不同之前