-2

我希望我的插件可以加载任何页面并更改其中的一些内容,因为我已经编写了内容脚本,并添加了外部 js 文件,在外部 js 文件中我无法访问 chrome.tab。* 我是做错了吗?

------ 内容脚本----

debugger;
var s = document.createElement('script');
            s.src = chrome.extension.getURL("script.js");
            (document.head||document.documentElement).appendChild(s);
            s.parentNode.removeChild(s);


            /*chrome.runtime.sendMessage('3645374', 'any message',[] , function(){  alert('---...---'); } )     ;   

chrome.tabs.executeScript(null, {file: "doWhatYouWant();"});


document.addEventListener('DOMContentLoaded', function() {
     chrome.tabs.onUpdated.addListener(function(tabId, changeInfo, tab) {
        if (changeInfo.status == 'complete') {
            var s = document.createElement('script');
            s.src = chrome.extension.getURL("script.js");
            (document.head||document.documentElement).appendChild(s);
            s.parentNode.removeChild(s);
            chrome.tabs.executeScript(null, {code:"doWhatYouWant();"});
        }
    });
});*/

-------------------- script.js --------------

function doWhatYouWant(){
    alert('inside .... doWhatYouWant');
    document.getElementById('zx12').value = "CHANGED !";
}


chrome.tabs.onUpdated.addListener(function(tabId, changeInfo, tab) {
    if (changeInfo.status == 'complete') {
    debugger;
        alert('I am here too ');
        // Execute some script when the page is fully (DOM) ready
        chrome.tabs.executeScript(null, {code:"doWhatYouWant();"});
    }
});


/*chrome.extensions.onRequest.addLiestener( function(p1,p2,p3){
  alert('done');
  document.getElementById('zx12').value = "CHANGED !";
});



chrome.runtime.onMessage.addListener(function (){
   alert('doWhatYouWant called');
});



document.addEventListener('DOMContentLoaded', function() {
  document.getElementById('zx12').value = "CHANGED !";
});
*/

----------------------- manifest.json ---------------

{
  "name": "My Chrome Extension",
  "version": "1.0",
  "manifest_version": 2,
  "content_scripts": [{
      "matches": ["http://*/*","https://*/*"],
      "js": ["jquery.js","contentscript.js"]
  }],
  "web_accessible_resources" : ["script.js"],
  "permissions": [
    "activeTab"
  ]
}
4

1 回答 1

2

内容脚本不能使用大多数 Chrome 扩展 API。(chrome.extension.getURL您进行的调用是一个罕见的例外。)您可能需要chrome.tabs在扩展的背景页面中实现事件侦听器并将消息传递给内容脚本。

请阅读关于内容脚本的 Google Chrome 文档,尤其是关于限制的介绍部分和关于执行环境的部分。

于 2013-10-22T07:35:44.257 回答