我的目标是创建一个按钮,单击该按钮会删除 reddit 上已访问其链接的父 div。由于安全问题,无法从非特权 javascript 中检测到访问的链接状态,因此,我尝试了 chrome 扩展。但是,这似乎也不起作用,因为即使是从具有历史权限的扩展调用的 javascript 也会返回“未捕获的类型错误:无法调用未定义的方法‘搜索’。” 因此,我仍在寻找一种方法来做到这一点。
2013 年 1 月 8 日更新
我非常接近让这个工作,但是,我无法在内容脚本中获得 n_results 以准确反映其在后台脚本中的状态。有任何想法吗?最新代码如下。
2013 年 1 月 8 日更新
它正在工作!如果您需要执行上述操作,请参见下文。
清单.json
{
"name": "Never The Same (NTS) Reddit",
"version": "1.0",
"manifest_version": 2,
"description": "Previously visited links are deleted.",
"browser_action": {"default_icon": "icon.png"},
"permissions": ["history","tabs"],
"content_scripts": [
{
"run_at": "document_end",
"matches": ["http://www.reddit.com/*"],
"js": ["jquery-1.8.3.min.js", "ntsreddit_content.js"]
}
],
"background": {"scripts": ["ntsreddit_background.js"]}
}
ntsreddit_background.js
chrome.extension.onMessage.addListener(
function (request, sender) {
chrome.history.getVisits({"url": request.url},
function (visits) {
if (visits.length > 0) {
chrome.tabs.sendMessage(sender.tab.id, {
"url": request.url
});
};
});
});
ntsreddit_content.js
$("div.thing a.title").each(
function(index, value) {
chrome.extension.sendMessage({"url": value.href});
});
chrome.extension.onMessage.addListener(function (message) {
anchor=$('a[href^="' + message.url + '"][class~="title"]')
if (anchor.length > 0) {
anchor.closest(".thing").remove();
};
});