Chrome 扩展 javascript 功能未定义

Posted

技术标签:

【中文标题】Chrome 扩展 javascript 功能未定义【英文标题】:Chrome extension javascript function is not defined 【发布时间】:2011-10-23 23:34:18 【问题描述】:

我正在开发一个 chrome 扩展,遇到了一个我无法解决的问题;/

我编写了清单文件和一些 java 脚本代码。除了按钮,一切都很好。当我单击它们时,它们应该使用参数触发 echo 函数并将其进一步发送到在 firebreath 中开发的插件。当我在 html 文件中手动注入代码时,一切正常,但是当通过 javascript chrome 控制台注入代码时,会提示我未定义回显函数。我尝试了几种注入代码的方法,但都没有奏效。

所以我向其他程序员寻求帮助或一些好的建议。 (第一次发帖害羞

主 javascript 文件 chrome_script.js

var Reg = /(\+48\s?[0-9]3[\-\ ]?[0-9]3[\-\ ]?[0-9]3)|(\+48\s?[\(\ ]?[0-9]2[\)\ ]?[0-9]2,3[\-\ ]?[0-9]2[\-\ ]?[0-9]2)/g

var content = document.body.innerHTML;

var phoneNumbers = content.match(Reg);

document.getElementsByTagName('head')[0].innerHTML +='<script src="'+chrome.extension.getURL("plug_fun.js")+'" type="text/javascript"></script>';

content = "<object id=\"plugin0\" type=\"application/x-testplugin\" width=\"100%\" height=\"300\"></object>" + content;

for (var i = 0; i < phoneNumbers.length; i++) 
    content = content.replace(phoneNumbers[i], "<button id=\"" + i + "\" type=\"button\" onclick=\"javascript:echo(" + phoneNumbers[i].replace(new RegExp("[\+\ ]", "g"),"") + ")\">" + phoneNumbers[i] + "</button>");


document.body.innerHTML = content;

javascript 文件 plug_fun.js,用于插件和按钮

function plugin0()
    return document.getElementById('plugin0');

plugin = plugin0;  
function echo(a)
    var num = String(a);
    plugin().echo(num);

清单文件 manifest.json


    "name": "Phone Injection",
    "version": "0.2",
    "browser_action": 
        "default_icon": "Phone.ico"
    ,
    "permissions": [
            "tabs", "http://*/*", "https://*/*", "file://*"
    ],
    "plugins": [
         "path": "npTestPlugin.dll", "public": true 
        ],
    "content_scripts": [ 
        "matches": ["http://*/*", "https://*/*", "file://*"], 
        "js": ["chrome_script.js", "plug_fun.js"]
    ]

点击按钮时发现错误

Uncaught ReferenceError: echo is not defined

【问题讨论】:

【参考方案1】:

Chrome 扩展程序中的内容脚本在 Google 所谓的“孤立世界”中执行。这意味着不允许不同的脚本相互查看或交互,并且看起来好像页面上没有执行其他 JavaScript。请参阅下面直接从 Google 文档获取更多信息:

内容脚本在称为孤立世界的特殊环境中执行。他们可以访问被注入页面的 DOM,但不能访问页面创建的任何 JavaScript 变量或函数。它查看每个内容脚本,就好像它正在运行的页面上没有其他 JavaScript 执行一样。反过来也是如此:在页面上运行的 JavaScript 不能调用任何函数或访问由内容脚本定义的任何变量。 引用自:http://code.google.com/chrome/extensions/content_scripts.html#execution-environment

我建议尝试将与 firebreath 插件交互的代码放在后台脚本中,尽管我会仔细检查并确保这些代码也不会在隔离环境中执行。

【讨论】:

后台页面也被隔离了;/ 感谢您的帮助,我确实设法通过后台页面和通过消息与脚本进行通信来做到这一点。【参考方案2】:

NPAPI 插件(包括在FireBreath 中开发的插件)在将它们放入页面后并不总是可用和立即可用。我会首先尝试设置一个 setTimeout 来延迟尝试调用 plugin().echo() 大约一秒钟;如果这不起作用,你的问题是别的。如果它确实有效,那么您可以添加一个 onload 参数标记,其中包含插件启动时应调用的函数名称。请注意,NPAPI 只允许在 param 标签中传递字符串,因此它必须是全局函数的名称。

有关使用 onload 参数的示例,请参阅 FireBreath FBTestPlugin test.html。

【讨论】:

好吧,我认为这不会有帮助,因为 javascript 函数“echo”甚至没有被调用,所以插件方法没有被访问。 如果问题是我所建议的,那么当您尝试调用 echo 以调用它时,插件加载不足;或者你是说你已经追踪到那个点并且你确定那行javascript没有被执行?因为如果插件加载不足,你肯定无法在调试器中捕获调用,因为调用永远不会到达插件。 我认为像@WadeNorris 所说的那样,隔离是一个问题。在后台页面插件工作正常。【参考方案3】:

尝试按如下方式重新排列清单;

"content_scripts": [ 
    "matches": ["http://*/*", "https://*/*", "file://*"], 
    "js": ["plug_fun.js", "chrome_script.js"]
]

现在,在chrome_script.js 中,您不需要手动添加plug_fun.js 文件,因为清单已经提前为您加载了它,所以希望您现在应该发现echo 存在。但是,我不能 100% 确定,因为我从未在我的内容脚本中使用过这种分隔。

【讨论】:

以上是关于Chrome 扩展 javascript 功能未定义的主要内容,如果未能解决你的问题,请参考以下文章

Chrome扩展程序 - 记住用户输入JavaScript

使用 javascript 将文本插入 textarea 以用于 google chrome 扩展

如何开发一个chrome扩展

IE 扩展 - 注入 Javascript 文件

如何开发Chrome扩展程序

使用 JavaScript 将 Chrome 扩展注入 iFrame