Chrome 扩展 getUrl 在注入文件中不起作用

新手上路,请多包涵

我正在开发 Chrome 扩展程序,有没有办法从注入文件中获取 chrome.extension.getURL('file path') 方法?我无法从注入的文件访问上述方法。

清单.json

 {
"name": "Name",
"version": "0.1",
"description": "Name chrome extension",
"background": {
"persistent": false,
"scripts": ["js/background.js"]
},
"permissions": [
"tabs",
"https://*/*"
],
"content_scripts": [
{
  "matches": ["https://mail.google.com/*"],
  "js": ["js/content.js"],
  "run_at": "document_end"
}
],
"web_accessible_resources": [
"js/injected.js",
"html/popup.html"
],
"manifest_version": 2
}

注入.js

 console.log("Ok injected file worked");
console.log("Url: ", chrome.extension.getURL('html/popup.html'));

内容脚本.js

 var s = document.createElement('script');
s.src = chrome.extension.getURL('js/injected.js');
(document.head || document.documentElement).appendChild(s);

原文由 Bharath Kumar 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 1.1k
2 个回答

不,你不能,一旦你在页面中注入脚本,它就无法访问 chrome.extension.getURl 。但是您可以在 injected scriptcontent script 之间进行通信。其中一种方法是使用自定义事件。

mainfest.json :

 {
"name": "Name",
"version": "0.1",
"description": "Name chrome extension",
"background": {
"persistent": false,
"scripts": ["js/background.js"]
},
"permissions": [
"tabs",
"https://*/*"
],
"content_scripts": [
{
  "matches": ["https://mail.google.com/*"],
  "js": ["js/content.js"],
  "run_at": "document_end"
}
],
"web_accessible_resources": [
"js/injected.js",
"html/popup.html"
],
"manifest_version": 2
}

在你的 injected script

 console.log("Ok injected file worked");

document.addEventListener('yourCustomEvent', function (e)
{
    var url=e.detail;
    console.log("received "+url);
});

在你的 content script

 var s = document.createElement('script');
s.src = chrome.extension.getURL('js/injected.js');
(document.head || document.documentElement).appendChild(s);

s.onload = function(){

  var url=chrome.runtime.getURL("html/popup.html");

  var evt=document.createEvent("CustomEvent");
  evt.initCustomEvent("yourCustomEvent", true, true, url);
  document.dispatchEvent(evt);
};

原文由 Sid 发布,翻译遵循 CC BY-SA 3.0 许可协议

chrome.extension.getURL 现已弃用。 文档

在后台脚本中使用 chrome.runtime.getURL

您需要从您的 contentScript 发送一条消息到 backgroundScript

例如。

 // contentScript.js

chrome.runtime.sendMessage({ message: "popup" }, function (response) {
  //
});

 // backgroundScript.js

chrome.runtime.onMessage.addListener((request, sender, sendResponse) => {
  if (request.message === "popup") {
    chrome.tabs.create({ url: chrome.runtime.getURL("popup.html") });
  }
});

原文由 Anurag Bhagsain 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
logo
Stack Overflow 翻译
子站问答
访问
宣传栏