注入脚本时出错

时间:2016-05-03 10:35:49

标签: javascript google-chrome-extension

我正在尝试开发Chrome扩展程序以在按钮单击时打开新选项卡,然后在其中执行js。

清单:

{
  "author": "...",
  "name": "...",
  "manifest_version": 2,
  "version": "1.0",
  "description": "...",
  "background": {},
  "browser_action": {
    "default_popup": "popup.html"
  },
  "permissions": [
    "tabs","http://*/","https://*/"
  ]
}

popup.html:

<html>
<head>
  <script src="jquery.min.js"></script>
</head>
<body>
  <button type="button" id="saveBtn">Save</button>
  <script type="text/javascript" src="popup.js"></script>
</body>
</html>

popup.js:

$("#saveBtn").click(function(){
  chrome.tabs.create({
    selected:false, 
    url:'https://analytics.google.com/something...'
  },function(tab){
    chrome.tabs.executeScript(tab.ib,{file:"jquery.min.js"});
    chrome.tabs.executeScript(tab.ib,{file:"html2canvas.js"});
    chrome.tabs.executeScript(tab.ib,{file:"FileSaver.js"});
    chrome.tabs.executeScript(tab.id,{file:'inject.js'});
  });
});

所有javascript文件都在同一个文件夹中。我收到此错误

Unchecked runtime.lastError while running tabs.executeScript: Cannot access a chrome:// URL at Object.callback (chrome-extension://jamfjopkccgnbpkhafanifhjambepphc/popup.js:8:23)

在我试图注入jquery.min.js,html2canvas.js和FileSaver.js的行上但不是inject.js!新选项卡正确打开,执行回调但然后抛出错误。我在这里做错了什么?

1 个答案:

答案 0 :(得分:2)

你那里有一个错字。

chrome.tabs.executeScript(tab.ib,{file:"jquery.min.js"});
chrome.tabs.executeScript(tab.ib,{file:"html2canvas.js"});
chrome.tabs.executeScript(tab.ib,{file:"FileSaver.js"});
chrome.tabs.executeScript(tab.id,{file:'inject.js'});

前三个有tab.ib而不是tab.id,它将通过undefined。在这种情况下,Chrome会尝试在当前标签中运行该脚本,该标签可能是chrome://extensions或类似的内容。

来自文档:

  

整数(可选)tabId
  要运行脚本的选项卡的ID; 默认为当前窗口的活动标签

顺便说一下,您可能需要查看this question以确保您的脚本按正确的顺序执行。