如何在 javascript(chrome 扩展) 中获取选项卡或窗口的当前 URL
2017-06-21
6287
我正在开发一个 Chrome 扩展程序,我们可以在其中共享处于活动状态的选项卡或窗口的当前 URL。我在获取 javascript 中当前活动的 URL 时遇到了一些问题。
已尝试
var current_url = window.location.host;
, var current_url = window.location.hostname;
, var current_url = window.location.href;
and var current_url = document.location.href;
这是 URL 传递函数的代码:(background.js):
chrome.runtime.onMessage.addListener(function(message,sender,sendResponse){
if(message.message=='openurl'){
chrome.tabs.query({active: true, currentWindow: true}, function(tabs){
var tab = tabs[0];
var page_url = tab.url;
wayback_url = message.wayback_url;
var pattern = /https:\/\/web\.archive\.org\/web\/(.+?)\//g;
url = page_url.replace(pattern, "");
open_url = wayback_url+encodeURI(url);
if(message.method!='save'){
status = wmAvailabilityCheck(page_url,
function(){ chrome.tabs.create({ url: open_url});
sendResponse({status:true});
},
function(){
//alert("URL not found in wayback archives!");
sendResponse({status:false});
});
}
else{
chrome.tabs.create({ url: open_url});
}
});
}
else if(message.message=='geturl') {
chrome.tabs.query({active: true, currentWindow: true}, function(tabs) {
var tab = tabs[0];
var page_url = tab.url;
if(isValidSnapshotUrl(page_url)){
sendResponse({url: page_url});
}
});
}
return true;
});
popup.js 的代码:
function get_alexa_info(){
chrome.runtime.sendMessage({message: "geturl" }, function(response) {
shareon_facebook(response.url);
shareon_twitter(response.url);
shareon_googleplus(response.url);
}
function shareon_facebook(url)
{
var current_url = url;
var fbshr_url = "https://www.facebook.com/sharer/sharer.php?u="
window.open(fbshr_url + current_url , 'newwindow', 'width=500, height=400');
}
function shareon_twitter(current_url)
{
var twitshr_url = "https://twitter.com/home?status=";
window.open(twitshr_url + current_url , 'newwindow', 'width=500, height=400');
}
function shareon_googleplus(url)
{
var gplusshr_url = "https://plus.google.com/share?url=";
window.open(gplusshr_url + url , 'newwindow', 'width=500, height=400');
}
由于其他原因,我无法提供有关此扩展程序的更多信息。
1个回答
如果您想获取活动标签的 URL,请尝试以下操作:
chrome.tabs.query({'active': true, 'lastFocusedWindow': true}, function
(tabs) {
var url = tabs[0].url;
document.getElementById("host").innerHTML = url;
});
然后您可以在 html 文件中显示它,如下所示:
<div id="host"></div>
Juan Gerardo
2018-03-18