我正在尝试为自己构建一个扩展浏览器。这个想法是,当我单击插件的图标时,它会打开一个页面。然后我想在新页面完成加载后执行一些代码,但不知何故它不起作用。
var result;
chrome.browserAction.onClicked.addListener(function() {
chrome.history.search(
{ text: "", maxResults: 100}, //object
function(results) { //callback
for(var item in results) {
var currItem = results[item];
if (currItem.url.indexOf("some_domain") > -1) {
result = results[item];
break;
}
}
//Go to website
chrome.tabs.create({
'url': result.url
}, function(tab) {
new_tabId = tab.id;
});
}
);
});
现在来了失败的部分:
chrome.webNavigation.onCompleted.addListener(function(details) {
// if (check for correct URL here) {
var videos = document.getElementsByTagName("video");
var video = videos[0];
alert(videos.length); <--- always Zero! Why??
video.load();
video.play();
video.addEventListener("ended", function() { ... });
// }
});
它们都在同一个背景脚本中,我没有内容脚本。清单中的权限是"tabs", "history", "webNavigation"
当我与开发人员控制台核对并执行以下操作时:
document.getElementsByTagName("video").length
我确实得到了正确的号码。