微信小程序——星星评分
先来个效果图镇楼:
实现原理:
1.循环需要评分的列表,判断它的分数 与 当前星星索引的大小;
2.点击,获取星星对应的分数,让星星高亮。
代码:
star.wxml:
<view class="weui-cells {{!margin ? 'weui-cells__mt0' : ''}}"> <view class='weui-cell' wx:for="{{subjectStarList}}" wx:key="id" wx:for-item="subjectStar" wx:for-index="subIdx"> <view class='weui-cell__bd'> {{subjectStar.name}} </view> <view class='weui-cell__ft'> <view class='score-list'> <ss-icon wx:for="{{stars}}" wx:for-item="stars" name="star-full" custom-class=" score-item {{subjectStar.score > index ? 'active' : ''}} " data-sub-idx="{{subIdx}}" data-score="{{stars}}" bind:click="grade"></ss-icon> </view> </view> </view> </view>
上面的ss-icon 是我自定义的一个组件,点击查看。
主要代码说明:
{{subjectStar.score > index ? 'active' : ''}} —— 当前的分数如果大于当前星星的索引,就给它添加 active 样式,就是让它变成高亮黄色;
data-sub-idx="{{subIdx}}" —— 获取你当前点击的是第几项
data-score="{{stars}}" —— 当前你的星星对应的是几分
star.js:
// components/star/index.js Component({ options: { addGlobalClass: true, }, /** * 组件的初始数据 */ data: { subjectStarList: [{ id: 1, name: '学校表现', score: 1 }, { id: 2, name: '作业完成情况', score: 4 }, { id: 3, name: '爱护同学', score: 0 }], stars: [1, 2, 3, 4, 5] },/** * 组件的方法列表 */ methods: { grade: function(e) { let that = this; let score = e.currentTarget.dataset.score; let subIdx = e.currentTarget.dataset.subIdx; let subScore = `subjectStarList[${subIdx}].score`; //只有一颗星的时候,再次点击,变为0颗 if (that.data.subjectStarList[subIdx].score == 1 && score == 1) { score = 0; } that.setData({ [subScore]: score, }); }, } })
注意!!我是把这个评分功能做成的一个组件形式,所以js 文件里面主要是组件写法。这里主要介绍一下它的原理~
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用