微信小程序利用wxs做星星评分
数据结构(注意这是根据真实数据来写的,自己用的时候需要注意)
questionList:[
{
maxScore:5,//最大星星数量
userAnswer:'',//回显是的分数也可以用来储存点击时的分数
}
]
answerList 这个数后台需要的分数集合可以忽略
wxml部分
<wxs module="score">
var getScoreType = function(ind, score){//第一个参数为当前列第几个星星,第二个参数为当前列的分数
if(score){
var startFullIndex = score/2
if(ind+1 <= startFullIndex){
return 'full'
}else if(ind+1 > startFullIndex && ind+1 < startFullIndex+1){
return 'half'
}else{
return 'null'
}
}else{
return 'null'
}
}
module.exports.getScoreType = getScoreType
</wxs>
<view class="stars clearfix">
<view wx:for="{{item.maxScore}}" wx:for-index="idx" wx:key="idx" wx:for-item="itemImg" class="stars-list {{score.getScoreType(idx, answerList[index])}}">
<view class="stars-view" data-score="{{(idx+1)*2-1}}" data-index="{{index}}" bindtap="{{finish||evaFinish ? '' : 'starClick'}}"></view>
<view class="stars-view" data-score="{{(idx+1)*2}}" data-index="{{index}}" bindtap="{{finish || evaFinish ? '' : 'starClick'}}"></view>
</view>
</view>
js部分
监听数据 (放置data下面即可)
observers:{ //questionList需要注意这个要换成自己的需要监听的变量
'questionList':function(val){
if(val.length> 0){
val.map(v => {
if(this.data.finish||this.data.evaFinish){//此处是判断回显
this.data.answerList.push(v.userAnswer)
}else{
this.data.answerList.push('')
}
})
this.setData({
answerList:this.data.answerList
})
}
}
},
methods:{
starClick:function(e){
// 点击星星
let {index, score} = e.currentTarget.dataset;//获取wxml上面绑定的分数和题的下标
this.data.answerList[index] = score
this.setData({
answerList: this.data.answerList
})
},
}
wxss部分
如果样式展示有问题,那么就自己微调下吧
.stars{
display: flex;
flex-direction:row;
}
.stars .stars-list{
display: flex;
flex-direction:row;
width: 40rpx;
padding-right: 10rpx;
padding-left: 10rpx;
height: 40rpx;
position: relative;
}
.stars-view{
width: 30rpx;
background: transparent;
color: rgba(255, 255, 255, 0);
position: absolute;
top: 0;
left: 0;
height: 40rpx;
}
.stars-view:nth-of-type(even){
width: 30rpx;
background: transparent;
color: rgba(255, 255, 255, 0);
position: absolute;
top: 0;
left: 30rpx;
height: 40rpx;
}
.list .stars .null {
background: url()
no-repeat center center;
background-size: contain;
}
.list .stars .full {
background: url()
no-repeat center center;
background-size: contain;
}
.list .stars .half {
background: url()
no-repeat center center;
background-size: contain;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
· 如何调用 DeepSeek 的自然语言处理 API 接口并集成到在线客服系统
2021-04-22 js 中 call() 、apply()和 bind()的区别
2021-04-22 什么是深拷贝和浅拷贝?