我是一个名为 BeautifyTumblr 的插件的制造者,它改变了 Tumblr 的外观。我希望我的 Chrome 扩展程序能够自动检测何时更新并向用户显示更改日志。我使用带有 chrome.runtime.onInstalled.addListener 钩子的事件页面来检测何时发生更新,从扩展中的文本文件中检索更改日志。这一切正常,然后当我想将其转发到我的内容时通过 chrome.tabs.sendmessage 编写脚本它只是无法工作,什么都没有发生,没有错误,什么都没有。我难住了。
任何帮助将非常感激!
活动页面:
chrome.runtime.onInstalled.addListener(function (details) {
"use strict";
if (details.reason === "install") {
} else if (details.reason === "update") {
var thisVersion = chrome.runtime.getManifest().version, xmlDom, xmlhttp;
xmlDom = null;
xmlhttp = new XMLHttpRequest();
xmlhttp.open("GET", chrome.extension.getURL("changelog.txt"), false);
xmlhttp.send(null);
xmlDom = xmlhttp.responseText;
chrome.tabs.query({'url' : 'http://www.tumblr.com/*'}, function (tabs) {
if (tabs.length > 0) {
var mTab = tabs[0].id;
chrome.tabs.update(mTab, {active: true});
setTimeout(chrome.tabs.sendMessage(mTab, {beautifyTumblrUpdate: xmlDom}), 500);
} else {
chrome.tabs.create({'url' : 'http://www.tumblr.com/dashboard'}, function (tab) {
setTimeout(chrome.tabs.sendMessage(tab.id, {beautifyTumblrUpdate: xmlDom}), 500);
});
}
});
}
});
内容脚本中的相关代码:
chrome.runtime.onMessage.addListener(
function (request, sender, sendResponse) {
"use strict";
window.alert('test');
if (request.beautifyTumblrUpdate) {
window.alert(request.beautifyTumblrUpdate);
} else if (request.beautifyTumblrInstall) {
window.alert(request.beautifyTumblrInstall);
}
}
);