-
Notifications
You must be signed in to change notification settings - Fork 55
小程序自定义评分组件 template(精度0.1)
Honye edited this page Sep 28, 2018
·
3 revisions
在豆瓣评分中,最终影视评分最大值是10分,而在影评时最大值是5星。因此评分的最大值是可调的。
五角星也就两种状态,实星和空星。底部放置空星代表最大评分,顶部放置实星代表实际评分,只需计算出实星与空星的比例,使实星遮盖空星即可得到最终效果。前面的整星不用计算百分比,只需计算最后一个实星与空星的百分比即可。
简单计算流程:
五角星数量num: 5
最大评分max: 10
一颗星代表unit: max/num = 2
实际评分value: 7.3
去除整星剩余百分比percent: value%unit/unit
为避免计算精确问题从而使用整数运算
最终: percent = (value10)%(unit10)/(unit*10)
这里使用到了 FontAwesome,可以查看 小程序使用外部字体
<template name="rating">
<view class='com-rating'>
<block wx:for='{{[1,2,3,4,5]}}' wx:key='*this'>
<view class='rating-on'
style='width:{{rating >= (max/5)*item ? 1 : rating < (max/5)*(item-1) ? 0 : (rating*10)%(max/5*10)/(max/5*10)}}em'
><i class='fa fa-star'></i></view>
<view class='rating-off'><i class='fa fa-star'></i></view>
</block>
</view>
</template>
.com-rating {
display: inline-block;
font-size: 1.2em;
letter-spacing: .3em;
}
.com-rating .rating-on,
.com-rating .rating-off {
display: inline-block;
}
.com-rating .rating-on {
color: black;
position: absolute;
overflow: hidden;
padding: 0;
margin: 0;
}
.com-rating .rating-off {
color: #DBDBDB;
padding: 0;
margin: 0;
}
page.wxml
<import src='../rating/rating' />
...
<template is='rating' data='{{rating:7.3, max:10}}'></template>
page.wxss
@import '../rating/rating';
...
因为图标使用的是字体文件,所以星星也可以改为任何文字、颜色,我这里只讲了如何去实现。
- 用户可操作评分
- 大小及间距可调
- 默认配置
完整源码及使用可查看我的开源项目 weapp-mark