CSS ::before ::after 伪元素动态宽度

CSS ::before ::after pseudo elements dynamic width

我想用单个 div 元素和像 ::before.

这样的 css 伪元素制作星级进度条

我唯一不能做的就是用 Javascript.

操纵 ::before 元素的宽度

这是我的例子:

.review-rate {
 background-image: url();
 background-repeat: repeat-x;
 width: 100px;
 height: 18px;
}
.review-rate::before {
 content: "";
 display: block;
 width: attr(data-width);
 height: 18px;
 width: 55%;
 background-image: url();
 background-repeat: repeat-x;
 background-position: 0 -18px;
}
<div class="review-rate" data-toggle="review" data-value="3.5" data-width="50" data-count="17"></div>

有什么方法可以操纵 ::before 元素的 width 吗?

也许是 width: attr(data-width);

任何帮助将不胜感激。

虽然不理想,但您可以使用具有新 width 值的 jQuery 将新的 <style> 元素附加到页面。

$('head').append('<style>.review-rate:before{width:75%}</style>');

这是一个demo

更新
正如 Imran 在下面的评论中指出的那样,随着时间的推移,上述方法会导致许多 <style> 标签。为了防止这种情况,可以使用 appendreplaceWith 的组合来将 <style> 标签的数量保持在最低限度。

if ($('head style[data-class="review-rate"]').length) {
    $('head style[data-class="review-rate"]').replaceWith('<style data-class="review-rate">.review-rate:before{width:75%}</style>')       
} else {
    $('head').append('<style data-class="review-rate">.review-rate:before{width:35%}</style>');
}

我知道动态更改 :before & :after css 的一种方法是 @Brett DeWoody 提到的添加样式标签。

在您的情况下,您可以简单地切换 :beforediv 的角色。然后使用 div 宽度而不是 :before。像这样:

.review-rate {
background-image: url("");
background-position: 0 -18px;
background-repeat: repeat-x;
height: 18px;
overflow: visible;
position: relative;
width: 50px;
}
.review-rate::before {
background-image: url("");
background-repeat: repeat-x;
content: "";
display: block;
height: 18px;
position: relative;
width: 100px;
z-index: -1;
}
 <div class="review-rate" data-toggle="review" data-value="3.5" data-width="50" data-count="17"></div>