ГМ addStyle эквивалент в Tampermonkey в
есть ли эквивалент TamperMonkey для GreaseMonkey GM_addStyle
метод добавления CSS?
в GreaseMonkey вы можете добавить кучу свойств CSS к нескольким элементам, например:
GM_addStyle("body { color: white; background-color: black; } img { border: 0; }");
чтобы сделать эквивалент в TamperMonkey, я в настоящее время должен сделать следующее:
function addGlobalStyle(css) {
var head, style;
head = document.getElementsByTagName('head')[0];
if (!head) { return; }
style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = css;
head.appendChild(style);
}
addGlobalStyle('body { color: white; background-color: black; }');
это работает, но есть встроенный GM_addStyle
эквивалент для TamperMonkey, который избавляет меня от необходимости повторять это на каждом скрипте?
3 ответов
По данным в Tampermonkey в документации, он поддерживает GM_addStyle
напрямую, как это делает GreaseMonkey. проверьте правильность правил включения/соответствия, затем добавьте этот демо-код в верхнюю часть вашего userscript:
GM_addStyle('* { font-size: 99px !important; }');
console.log('ran');
Я только что протестировал его на новом userscript в Chrome 35, и он работал, как ожидалось. Если у вас есть другие @grant
правила, вам необходимо добавить один для этой функции, в противном случае он должен быть определен и предоставлен автоматически.
версия 4.0 или +, обновление 2018
ReferenceError: GM_addStyle is not defined
вам нужно создать свою собственную функцию GM_addStyle, например:
// ==UserScript==
// @name Example
// @description Usercript with GM_addStyle method.
// ==/UserScript==
function GM_addStyle(css) {
const style = document.getElementById("GM_addStyleBy8626") || (function() {
const style = document.createElement('style');
style.type = 'text/css';
style.id = "GM_addStyleBy8626";
document.head.appendChild(style);
return style;
})();
const sheet = style.sheet;
sheet.insertRule(css, (sheet.rules || sheet.cssRules || []).length);
}
//demo :
GM_addStyle("p { color:red; }");
GM_addStyle("p { text-decoration:underline; }");
document.body.innerHTML = "<p>I used GM_addStyle.</p><pre></pre>";
const sheet = document.getElementById("GM_addStyleBy8626").sheet,
rules = (sheet.rules || sheet.cssRules);
for (let i=0; i<rules.length; i++)
document.querySelector("pre").innerHTML += rules[i].cssText + "\n";
устарел
если GM_addStyle(...)
не работает, проверьте, есть ли у вас @grant GM_addStyle
заголовок.
такой :
// ==UserScript==
// @name Example
// @description See usercript with grant header.
// @grant GM_addStyle
// ==/UserScript==
GM_addStyle("body { color: white; background-color: black; } img { border: 0; }");
Если кто-то заинтересован, я изменил код, чтобы вам не нужно было писать "!важно " после каждого правила css. Конечно, это работает только в том случае, если вы используете функцию вместо GM_addStyle.
function addGlobalStyle(css) {
var head, style;
head = document.getElementsByTagName('head')[0];
if (!head) { return; }
style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = css.replace(/;/g, ' !important;');
head.appendChild(style);
}
вывод этого"addGlobalStyle('body { color: white; background-color: black; }');
",
будет "body { color: white !important; background-color: black !important; }');
"