Chrome.tabs.update和chrome.tabs.executeScript的chrome.tabs问题

时间:2011-01-03 12:43:18

标签: google-chrome google-chrome-extension

我想写一个小的chrome扩展,它将从网页A(当前网页)获取信息,将标签更新到网页B,然后将代码注入网页B.不幸的是,以下代码将网页更新为B但是注入网页的代码A. background.html中的代码是:

chrome.tabs.update(tab.id,{url: "http://B.com"});
chrome.tabs.executeScript(tab.id, {file: "inject_into_B.com.js"}); /* injections goes misleadingly to webpage A*/

2 个答案:

答案 0 :(得分:5)

你想要这样的东西:

chrome.tabs.update(tab.id, {url: request.url, active: true}, function(tab1) {

    // add listener so callback executes only if page loaded. otherwise calls instantly
    var listener = function(tabId, changeInfo, tab) {

        if (tabId == tab1.id && changeInfo.status === 'complete') {
            // remove listener, so only run once
            chrome.tabs.onUpdated.removeListener(listener);
            // do stuff
        }
    }
    chrome.tabs.onUpdated.addListener(listener);
});

答案 1 :(得分:1)

chrome.tabs.update是异步调用(就像其他几乎一样),所以如果你想按顺序运行这些命令,你需要使用回调函数:

chrome.tabs.update(tab.id,{url: "http://B.com"}, function(tab) {
    chrome.tabs.executeScript(tab.id, {file: "inject_into_B.com.js"});
});