添加jQuery停止执行脚本
我试图编写一个Chrome扩展,在目标页面上放置一个小脚本,然后针对页面上的项目执行特定操作。作为Chrome扩展程序的新手,我已经开始使用“Hello World”警报。这工作正常,但是我实际上想要做的事情包括对对象使用jQUery。添加jQuery停止执行脚本
虽然我的目标页面已经导入jQuery,但如果我尝试在我的脚本中使用它,我会得到一个异常,即$未定义。但是,如果我自己尝试导入它,即使alert
停止工作。
下面是我的代码,任何人都可以指出我要去哪里错了吗?
manifest.json的
{ "manifest_version": 2,
"name": "Hello World",
"description": "Simple Hello World Extension",
"version": "1.0",
"content_scripts": [
{
"matches": ["http://localhost:46950/"],
"run_at": "document_end",
"js": ["http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js", "popup.js"]
}
]
}
popup.js
$(helloWorld()); function helloWorld()
{
alert("Hello World");
}
更新
挖掘到的Chrome://扩展,我意识到,当我尝试使用下面的代码,扩展名不是loade d到Chrome中。如果我尝试再次手动加载它,我会得到以下例外:
无法从“'加载扩展名。无法加载JavaScript内容脚本。
回答:
好吧,我设法找到this答案,这给了我一些线索发生了什么事。
Chrome看起来不会在扩展中的外部资源中加载。因此,当我试图通过谷歌加载jQuery,它不会加载它,并崩溃了整个扩展。
我试图这样做的原因是,以免导致我的多个版本的jquery在我的扩展和目标站点之间发生冲突的问题。但是,答案表明这些流程本质上是孤立运行的,所以它不应该有问题。考虑到这一点,我刚刚手动将jquery添加到我的扩展中,并直接加载它。这似乎工作正常。
manifest.json的
{ "manifest_version": 2,
"name": "Hello World",
"description": "Simple Hello World Extension",
"version": "1.0",
"content_scripts": [
{
"matches": ["http://localhost:46950/"],
"run_at": "document_end",
"js": ["jquery-2.0.3.min.js", "popup.js"]
}]
}
回答:
JQuery期待一个DOM元素,所以它会抛出一个错误。
这听起来像你正在寻找类似的$(document)。就绪(): http://learn.jquery.com/using-jquery-core/document-ready/
以上是 添加jQuery停止执行脚本 的全部内容, 来源链接: utcz.com/qa/257527.html