为 JSON 中的 URL 列表获取 Chrome pageAction 图标
Get Chrome pageAction icon to appear for an URL list in JSON
我目前正在开发一个 Chrome 扩展,我希望 pageAction 图标显示 URL 的数量(大约 500)。
在我的 background.js 文件(以及其他代码)中,我有这个:
// Called when the url of a tab changes
function checkForValidUrl(tabId, changeInfo, tab) {
// If the tabs url starts with "http://specific_domain"
if (tab.url.indexOf('http://specific_domain') == 0) {
// Shows the page action
chrome.pageAction.show(tabId);
}
};
// Listen for any changes to the URL of any tab
chrome.tabs.onUpdated.addListener(checkForValidUrl);
我已经可以让它在特定站点上运行,但我想将“http://specific_domain”更改为允许站点列表,例如白名单。我可以访问在线的 JSON 文件。
这是它的一个片段:
{
"antelife.com": {
"fbid": "AntElifecom",
"type": "store",
"name": "AntElife"
},
"amazon.com": {
"fbid": "Amazon",
"type": "store",
"name": "Amazon"
},
"ebay.com": {
"fbid": "eBay",
"type": "store",
"name": "eBay"
},
"mobilegeeks.com": {
"fbid": "mobilegeekscom",
"type": "publisher",
"name": "Mobile Geeks"
}
}
我想提取域,并以某种方式对所有域进行迭代,如果它们在列表中,则应该显示 pageAction 图标。像这样:
function checkForValidUrl(tabId, changeInfo, tab) {
for (var i = 0, iLength = whiteListUrl.length; i < iLength; i++) {
if (tab.url.indexOf('http://www.'+whiteListUrl[i]) > -1) {
chrome.pageAction.show(tabId);
notification.show();
break;
}
}
};
chrome.tabs.onUpdated.addListener(checkForValidUrl);
任何形式的帮助都应该有用。非常感谢。
如果你有一个 json 字符串,你可以通过这种方式得到 url 的列表;
var urlObj = JSON.parse(jsonString);
var whiteListUrl = Object.keys(urlObj);
我目前正在开发一个 Chrome 扩展,我希望 pageAction 图标显示 URL 的数量(大约 500)。
在我的 background.js 文件(以及其他代码)中,我有这个:
// Called when the url of a tab changes
function checkForValidUrl(tabId, changeInfo, tab) {
// If the tabs url starts with "http://specific_domain"
if (tab.url.indexOf('http://specific_domain') == 0) {
// Shows the page action
chrome.pageAction.show(tabId);
}
};
// Listen for any changes to the URL of any tab
chrome.tabs.onUpdated.addListener(checkForValidUrl);
我已经可以让它在特定站点上运行,但我想将“http://specific_domain”更改为允许站点列表,例如白名单。我可以访问在线的 JSON 文件。
这是它的一个片段:
{
"antelife.com": {
"fbid": "AntElifecom",
"type": "store",
"name": "AntElife"
},
"amazon.com": {
"fbid": "Amazon",
"type": "store",
"name": "Amazon"
},
"ebay.com": {
"fbid": "eBay",
"type": "store",
"name": "eBay"
},
"mobilegeeks.com": {
"fbid": "mobilegeekscom",
"type": "publisher",
"name": "Mobile Geeks"
}
}
我想提取域,并以某种方式对所有域进行迭代,如果它们在列表中,则应该显示 pageAction 图标。像这样:
function checkForValidUrl(tabId, changeInfo, tab) {
for (var i = 0, iLength = whiteListUrl.length; i < iLength; i++) {
if (tab.url.indexOf('http://www.'+whiteListUrl[i]) > -1) {
chrome.pageAction.show(tabId);
notification.show();
break;
}
}
};
chrome.tabs.onUpdated.addListener(checkForValidUrl);
任何形式的帮助都应该有用。非常感谢。
如果你有一个 json 字符串,你可以通过这种方式得到 url 的列表;
var urlObj = JSON.parse(jsonString);
var whiteListUrl = Object.keys(urlObj);