css实现五星好评样式

五星好评的样式,很多地方都有简单实现,比如设置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页面上是没问题的。

相关推荐
夏幻灵9 小时前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_10 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝10 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions10 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发10 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_10 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞0510 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
我爱加班、、10 小时前
Websocket能携带token过去后端吗
前端·后端·websocket
AAA阿giao10 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
杨超越luckly10 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强