Изменить размер картинки, вставленной через content нельзя
Можно вставить псевдоэлемент after как блок и задать ему картинку, как background.
Размеры лучше указывать непосредственно в пикселях, т.к. при указании в % эти % берутся не от размера картинки, а от размеров родительского блока.
<!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;
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 {
display: inline-block;
background-size: 24px 24px;
width: 24px;
height: 24px;
position: relative;
margin: 1px;
content: '';
vertical-align: middle;
}
.css_l[value="2"]::after { margin: 1px; }
</style>
</head>
<body bgproperties=fixed>
<div id="my_div"> </div>
<script>
var pic_b = [];
pic_b[3]="";
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('background-image', `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);
//
// теперь создаем кнопку с этим стилем
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>