当用户打开某个页面时,我想在打开新选项卡之前在现有选项卡中打开该页面。我尝试过 webRequest:
chrome.webRequest.onBeforeRequest.addListener(
function(details) {
chrome.tabs.query({ url: 'https://example.com/' },function (tabs) {
chrome.tabs.update(tabs[0].id, { url: details.url, highlighted: true });
})
},
{urls: ['https://example.com/']},
['blocking']
);
我也尝试过使用 webNavigation:
chrome.webNavigation.onBeforeNavigate.addListener(function (details) {
if(details.url=="https://example.com/") {
chrome.tabs.query({ url: 'https://example.com/' },function (tabs) {
chrome.tabs.update(tabs[0].id, { url: details.url, highlighted: true });
});
}
});
这两者都会打开一个必须关闭的新选项卡,并导致浏览器在选项卡之间跳转。
有没有办法在打开新选项卡之前拦截请求?
Thanks!
我最终把它解决了。这是代码的近似值:
function openMypageInMysite(tab) {
var urlNavigatingTo = tab.url,
matchMysiteUrl = urlNavigatingTo.match(/^https?:\/\/(.*).mysite.com\/?(.*)$/);
if (matchMysiteUrl) {
var pattern = '*://' + matchMysiteUrl[1] + '.mysite.com/*';
chrome.tabs.query({ url: pattern }, function(openTabs) {
var route = '/' + matchMysiteUrl[2];
Mytab = (openTabs[0].id !== tab.id) ? openTabs[0].id : openTabs[1].id;
chrome.tabs.sendMessage(Mytab, { route: route });
chrome.tabs.update(Mytab, { active: true });
chrome.tabs.remove(tab.id);
});
}
}
chrome.webNavigation.onBeforeNavigate.addListener(
function (details) {
openMypageInMysite({id: details.tabId, url: details.url});
},
{url: [{hostSuffix: 'mysite.com'}]}
);
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)