{
"description": "Demonstrating webRequests",
"manifest_version": 2,
"name": "webRequest-demo",
"version": "1.0",
"permissions": [
"webRequest",
"webRequestBlocking",
"<all_urls>"
],
"background": {
"scripts": ["background.js"]
}
}
chrome.webRequest.onBeforeRequest.addListener(
function(details) {
if (details.url.indexOf("://white.listed.site")) console.log("this is a response constructed by VPN extension");
return {cancel: details.url.indexOf("://www.evil.com/") !== -1}; // если нужно отменить запрос
},
{urls: ["<all_urls>"]},
["blocking"]
);
chrome.webRequest.onCompleted.addListener(
function(details){
console.log(`Catch ${details.method} response from ${details.url} ${details.fromCache ? '[ from cache ]' : ''} `)
},
{
urls: ["<all_urls>"]
}
);
"permissions": [
"webRequest"
// other permissions
chrome.webRequest.onCompleted.addListener(function(details){
console.log(`Catch ${details.method} response from ${details.url} ${details.fromCache ? '[ from cache ]' : ''} `)
}
const buf = Buffer.from(buffer.data);
const buf = Buffer.from(buffer);
let style = getComputedStyle(document.getElementById('radio'));
В вашем примере(до изменения свойства) backgroundColor === ''
. После того, как впервые измените его - возвращает действительный цвет. Т.е. это область видимости JS: в element.style видны только те свойства, которые менялись через JS. Но на работоспособность в вашем примере это никак не влияет. const players = data[0].locations[0].players;
const holes = new Array();
for (player of players){
holes.filter(f=>f.id === player.holeId).length === 0 ? holes.push({id: player.holeId, value: 1}) : holes.filter(f=>f.id === player.holeId)[0].value++;
}