首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用javascript更改psuedo元素的样式

用javascript更改psuedo元素的样式
EN

Stack Overflow用户
提问于 2018-04-26 11:27:20
回答 1查看 21关注 0票数 1

是否可以用javascript更改psuedo :after元素的样式,如下所示:

代码语言:javascript
复制
document.querySelector('#test:after').attr("style", "content:url('blabla.png')");

在单击1后,是否有任何变通方法来更改该图像:

代码语言:javascript
复制
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被展开时,它需要指向另一个方向。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-04-26 11:32:21

您不能用javascript更改伪元素的样式,因为它们不是DOM的一部分,因此没有任何API可以使用。

通常的方法是更改元素本身的类,并让这些类影响相关的伪元素。例如,在您的案例中:

代码语言:javascript
复制
// Add class selected to element
document.querySelector('#test').classList.add('selected')

在CSS中:

代码语言:javascript
复制
#test.selected::after {
  content: url('blabla.png');
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50041788

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档