9

我使用 CSS 制作了一个心形按钮。是我的代码的 JSFiddle 链接。

#heart {
  height: 50px;
  width: 50px;
  position: relative;
}
#heart .outline:before,
#heart .outline:after {
  position: absolute;
  content: "";
  left: 28px;
  top: 1px;
  width: 15px;
  height: 27px;
  background: #d53423;
  -moz-border-radius: 50px 50px 0 0;
  border-radius: 85px 60px 0 0;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
  -webkit-transform-origin: 0 100%;
  -moz-transform-origin: 0 100%;
  -ms-transform-origin: 0 100%;
  -o-transform-origin: 0 100%;
  transform-origin: 0 100%;
}
#heart .outline:after {
  left: 13px;
  -webkit-transform: rotate(45deg);
  border-radius: 45px 60px 0 0;
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  -webkit-transform-origin: 100% 100%;
  -moz-transform-origin: 100% 100%;
  -ms-transform-origin: 100% 100%;
  -o-transform-origin: 100% 100%;
  transform-origin: 100% 100%;
}
$("#heart").on('submit',
function(e) {
  console.log('click heart support');
  e.preventDefault();
  $('#heart .outline:before').css('background', 'grey');
}
);
<form id="heart">
  <button id="like_btn" class="outline" type="submit"></button>
</form>

当我单击表单按钮时,我希望这个心形按钮改变它的颜色。然而,这个心形按钮是由 CSS 伪元素制成的,因此我不能轻易改变它的颜色。

有没有人知道如何使用 JQuery操作 CSS 伪元素(例如:before和)?:after

4

3 回答 3

20

我设置:before :after背景颜色继承,然后更改其父级的背景颜色。http://jsfiddle.net/npMyy/3/

.outline {
    background: red;
}
#heart .outline:before, #heart .outline:after {
    background: inherit;
}
于 2013-04-29T14:06:19.283 回答
4

这似乎对我有用(Firefox 20)......没有在其他任何东西上测试过......

#heart .outline:active:before,
#heart .outline:active:after {
    background: #000;
}

这里,:active是一个伪类,:before:after是伪元素。所以根据标准这是完全可以接受的

选择器中的任何位置都允许使用伪类,而伪元素只能附加在选择器的最后一个简单选择器之后。

于 2013-04-29T13:50:43.310 回答
0

另一个解决方案是在提交时更改表单的类,:before:after使用修改后的选择器定位心脏孩子的类。虽然我真的很喜欢 NAT H 使用:active. 性感。只需对现有代码进行最小的更改。

演示

jQuery

$("#heart:not(.submitted)").on('submit',function(e){
    console.log('click heart support');     
    e.preventDefault();
    $('#heart').addClass('submitted');
});

css

// ... removed lines 

#heart.submitted .outline:before,
#heart.submitted .outline:after{
    background: grey;
}

html

<form id="heart" >
    <button id="like_btn" class="outline" type="submit" ></button>
</form>
于 2015-05-01T23:42:27.680 回答