是否可以用javascript更改psuedo :after元素的样式,如下所示:
document.querySelector('#test:after').attr("style", "content:url('blabla.png')");在单击1后,是否有任何变通方法来更改该图像:
var timesClicked = 0;
span = document.querySelector('.socialShare');
span.addEventListener('click', function (e) {
timesClicked++;
if (timesClicked > 1) {
document.querySelector('#socialShare').style.left = '-60px';
timesClicked = 0;
console.log(timesClicked)
} else {
document.querySelector('#socialShare').style.left = '0';
document.querySelector('#socialShare:after').attr("style", "content:url('blabla.png')");
console.log(timesClicked)
}
});或者更好地转换图像,它是关于一个箭头,当div被展开时,它需要指向另一个方向。
发布于 2018-04-26 11:32:21
您不能用javascript更改伪元素的样式,因为它们不是DOM的一部分,因此没有任何API可以使用。
通常的方法是更改元素本身的类,并让这些类影响相关的伪元素。例如,在您的案例中:
// Add class selected to element
document.querySelector('#test').classList.add('selected')在CSS中:
#test.selected::after {
content: url('blabla.png');
}https://stackoverflow.com/questions/50041788
复制相似问题