Спасибо большое,
Alexandroppolus, за ответ,
я тормоз, и так и не смог вытащить правильный руль.
Итак, имею:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head id="head"> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<style type="text/css" id="my_style_id">
.css_l { border-radius: 14px; border: 2px solid black; color: black; padding: 2px 2px; text-align: center; vertical-align: center; font-size: 14px; margin: 5px 5px; cursor: pointer; }
.css_l::before { content: attr(name); }
.css_l[value="0"]::after { margin: 6px; }
.css_l[value="1"]::after { margin: 1px; }
.css_l[value="2"]::after { margin: 1px; }
</style>
</head>
<body bgproperties=fixed>
<div id="my_div"> </div>
<script>
var pic_b = [];
pic_b[3]="";
pic_b[4]="";
function findRuleBySel(rules, selectorText)
{ if(!rules || !selectorText) return;
for(let i = 0; i<rules.length; i++)
{ const rule = findRuleBySel(rules[i].cssRules, selectorText) || ((rules[i].selectorText === selectorText) && rules[i]);
if(rule) return rule;
}
}
function ID(id) { return document.getElementById(id); }
function MainMenuInit()
{ // подкрутим картинки в css
let est = ID('my_style_id'); // Элемент style
let rules = est.sheet.cssRules; // Список правил
for (let i = 0; i<rules.length; i++) // печатаем на всякий случай все правила
console.log("[" + i + "]: " + rules[i].selectorText + " : " + rules[i].cssRules);
let rule;
rule=findRuleBySel(rules, ".css_l[value=\"1\"]::after"); // ищем правило с нужным селектором
rule.style.setProperty('content', `url('${pic_b[3]}')`); // засовываем туда картинку
console.log("1: " + rules + " : " + rule);
console.log(CSSStyleRule);
for (let i = 0; i<rule.length; i++) // не понимаю где искать размер, ищу, где могу, но не получается
console.log("[" + i + "]: " + rule[i].selectorText);
// rule=findRuleBySel(rule, "width"); // и тут искал
// console.log("2: " + rule);
// rule.setProperty("width", "20%");
rule=findRuleBySel(rules, ".css_l[value=\"2\"]::after"); // все то же самое для второй картинки
rule.style.setProperty('content', `url('${pic_b[4]}')`);
//
// теперь создаем кнопку с этим стилем
let par = document.createElement("button");
par.innerHTML="CH<sub>3</sub>-";
par.className="css_l";
par.value=1;
par.id="rd";
par.title="CH<sub>3</sub>-";
ID("my_div").appendChild(par);
ID("rd").addEventListener('click', RadicalsOnClick);
}
var RDVal=1;
function RadicalsOnClick() { ID("rd").value = RDVal = (RDVal+1)%3; }
MainMenuInit();
</script>
</body></html>
здесь полный пример, где, по совету
voraa я вставляю картинки, но, потом безуспешно пытаюсь поменять их размер.
Помогите, пожалуйста, найти правильный руль размера картинки!
Спасибо!