【发布时间】:2015-12-27 06:33:10
【问题描述】:
我正在尝试制作一个允许用户保存当前 URL 的 chrome 按钮。稍后,当他们重新登录时,我想将该 URL 发送到网站的数据库,但这超出了我当前的任务。
我想要的功能可以用这张图来概括:
我在下面的 URL 中发现了这个问题,但是 chrome 扩展的规则已经改变,并且该代码不再有效。 Get URL and save it | Chrome Extension
一条评论说: “从 manifest_version 2 开始,上述代码将不起作用。所有脚本应放在单独的文件中,然后将其包含在主 html 中。新版本明确指出不允许内联脚本和事件处理程序。”
我不知道如何实施这个人的建议。
到目前为止我所拥有的:
popup.hmtl
<html>
<body>
<p id="currentLink">Loading ...</p>
<hr />
<ul id="savedLinks"></ul>
<script type="text/javascript" src="popup.js"></script>
</body>
</html>
popup.js
chrome.tabs.query({'active': true}, function (tabs) {
var url = tabs[0].url;
});
清单:
{
"name": "URL Saver",
"version": "1.1",
"description": "A browser action that saves the url of the current open tab",
"permissions": [
"tabs"
],
"browser_action": {
"default_title": "URL CATCHER",
"default_icon": "icon.png",
"default_popup": "popup.html"
},
"manifest_version": 2,
"content_security_policy": "script-src 'self' https://ajax.googleapis.com; object-src 'self'"
}
现在,如果我单击该按钮,我只会收到“正在加载..._______”消息
【问题讨论】:
-
自该评论以来,该答案已更新。 manifest_version 2 不再有问题。
-
我不太明白你期望代码做什么。为什么将某些东西分配给(本地!)变量无论如何都会改变页面。
-
该功能无法在该图像中总结。请说明您希望发生什么以及何时发生。
-
我使用了下面的答案,它帮助我走得更远。我不是要成品,我只是想将其保存为局部变量,然后我会找到另一种方法将其推送到本地存储或直接推送到我网站的 API
标签: javascript google-chrome google-chrome-extension