五星好评的样式,很多地方都有简单实现,比如设置1星,2星,3星,4星,5星,这个没什么好说的,但是我有强迫症,我要是想看看4.5星的效果呢?就是有半颗星高亮。该如何实现呢?
我的想法是第一层做个默认没有星级的展示底图,然后把想要显示的五星级覆盖底层,然后设置覆盖层的宽度百分比。经过验证,这个思路是可以的。如下所示,
页面结构:
html
<view class="star-wrap">
<view class="star-gray">
<image class="icon-star" src="../icons/icon-grade-gray.png"></image>
<image class="icon-star" src="../icons/icon-grade-gray.png"></image>
<image class="icon-star" src="../icons/icon-grade-gray.png"></image>
<image class="icon-star" src="../icons/icon-grade-gray.png"></image>
<image class="icon-star" src="../icons/icon-grade-gray.png"></image>
</view>
<view class="star-gold" style='width:{{rate}}%'>
<image class="icon-star" src="../icons/icon-grade.png"></image>
<image class="icon-star" src="../icons/icon-grade.png"></image>
<image class="icon-star" src="../icons/icon-grade.png"></image>
<image class="icon-star" src="../icons/icon-grade.png"></image>
<image class="icon-star" src="../icons/icon-grade.png"></image>
</view>
</view>
样式:
css
.star-wrap{display: inline-block;position: relative;}
.star-wrap .icon-star{width:15px;height:15px;}
.star-wrap .star-gold{overflow: hidden;white-space: nowrap;position: absolute;top: 0;left: 0;}
动态js:
javascript
Component({
properties:{
grade:Number
},
data :{
rate : 0
},
ready() {
this.setData({
rate : this.data.grade/5.0 * 100
})
},
methods : {
onload() {
}
}
})
以上部分是做好了五星好评的组件样式,现在需要在页面上展示:
引入组件json:
javascript
{
"usingComponents": {
"fivestar-rater" : "../../components/fivestarrater"
}
}
页面使用:
html
<view class="fivestar-wrap">
<fivestar-rater grade="4.5"></fivestar-rater>
</view>
<view class="fivestar-wrap">
<fivestar-rater grade="3.5"></fivestar-rater>
</view>
<view class="fivestar-wrap">
<fivestar-rater grade="2.5"></fivestar-rater>
</view>
<view class="fivestar-wrap">
<fivestar-rater grade="1.5"></fivestar-rater>
</view>
<view class="fivestar-wrap">
<fivestar-rater grade="1"></fivestar-rater>
</view>
最终效果:

在覆盖层设置宽度的时候,根据父页面传入的grade值,做了一个简单的计算。这里需要传入宽度百分比,但是样式在wxss文件中又不能写死,只能在wxml页面上通过style="width:xx%"的方式传入,这里有点不太优雅,本来css有个函数attr()可以获取元素属性值作为变量,并设置width属性值的。可是微信小程序这里并不支持这么做。可以使用attr()函数,但是不生效。但是在一般的web页面上是没问题的。