通过以下代码向当前页面发送 “start” 消息:
chrome.tabs.query({active: true,currentWindow: true}, tabs => {
let tab = tabs[0];
chrome.tabs.sendMessage(tab.id, "start");
});
报错:
Uncaught (in promise) Error: Could not establish connection. Receiving end does not exist.
可能的原因:
接收端, 也就是说目标页面必须有 chrome.runtime.onMessage 监听消息, 如果 “content-script” 没有注入到页面中, 那么这个页面就无法接收消息
如果你的插件刚刚加载, 并且在一个已经加载完毕的页面中使用它, 则会出这个问题.
因为这个页面已经加载完了, 它并没有被注入脚本, 你需要刷新页面, 使脚本注入到页面中, 然后才可以发送消息
平台不允许文章内容太少, 下面是水
sendMessage
chrome.tabs.sendMessage(integer tabId, any message, function responseCallback)
向指定标签页中的内容脚本发送一个消息,当发回响应时执行一个可选的回调函数。当前扩展程序在指定标签页中的每一个内容脚本都会收到 runtime.onMessage 事件。
参数 | 类型 |
---|---|
tabId | integer |
message | any |
responseCallback | optional function |
如果您指定了 responseCallback 参数,它应该指定一个如下形式的函数:文章来源:https://www.toymoban.com/news/detail-414501.html
function(any response) {…};
response ( any )
请求处理程序发出的 JSON 响应对象。如果连接到指定标签页的过程中发生错误,将不传递参数调用回调函数,并将 runtime.lastError 设置为错误消息。文章来源地址https://www.toymoban.com/news/detail-414501.html
到了这里,关于Google Chrome 插件开发: 无法建立连接, 接收端不存在. Could not establish connection. Receiving end does not exist的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!