根据后端所给数据在页面相应展示星星数量

实现展示的效果图:

我这边写成组件可以参考一下:

用法 :<star :value="60"></star>
<template>
  <div class="star_box">
    <div class="star_item" v-for="index in 5" :key="index + 'star'">
       <!-- 执行starIndex方法 -->
      <img :src="imagePath[starIndex(index)].path" alt="" />
    </div>
  </div>
</template>

<script>
export default {
  props: {
    value: {
      type: Number || String,
      default: "99",
    },
  },
  data() {
    return {
      // 这个命名对应🌟 0就是空🌟 5就是半颗 8就是多半颗 10就是满星
      imagePath: [
        {
          path: "/image/0.png",
        },
        {
          path: "/image/05.png",
        },
        {
          path: "/image/08.png",
        },
        {
          path: "/image/10.png",
        },
      ],
    };
  },
  methods: {
    starIndex(index) {
      var value = this.value;
      // 达到条件让当前下标的🌟亮起
      switch (index) {
        case 1:
          return value >= 60 ? 3 : 0;
        case 2:
          return value >= 60 ? 3 : 0;
        case 3:
          return value >= 60 ? 3 : 0;
        case 4:
          return value >= 80 ? 3 : value >= 70 ? 1 : 0;
        case 5:
          return value > 95 ? 3 : value > 90 ? 2 : value > 80 ? 1 : 0;
      }
    },
  },
};
</script>

<style lang="scss">
.star_box {
  /* 继承父盒子的宽度 */
  width: 100%;
  /* 布局方式可以随意更改 */
  display: flex;
  justify-content: space-around;
  align-items: center;
  .star_item {
    /* 这里设置图片大小 */
    > img {
      width: 100%;
    }
  }
}
</style>

提供图片:
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值