mpvue 星星评价

商品的评价在每个商品中都会有展示,这种必定要写成组件的形式

1.创建组件

在这里插入图片描述

2.引入组件

哪里使用哪里引入

import Score from "@/components/Score.vue" //引入组件
  components:{
    Score
  },
3.使用并传参

这是的参数是1-10的数字,传到组件中进行处理

   <Score :score ="namedata.score"></Score>
方法一

使用这种方法如果是偶数或者满星的 情况下,for循环会出现空转报错的情况,不影响效果。

<template>
    <div>
        <img v-for="(scoreFloor,key) in scoreFloor" :key="key" src="../../static/images/b-star.png" />
        <img v-for="(scoreCeil,key) in scoreCeil" :key="key" src="../../static/images/b-half.png" />
        <img v-for="(scoreSurplus,key) in scoreSurplus" :key="key" src="../../static/images/gray-star.png"/>
    </div>
</template>
<script>
export default {
    name:"Score",
    props:["score"],//接收数据
    computed:{
        scoreFloor(){
            let resData = parseInt(this.score) / 2
            return Math.floor(resData)//整数星星的个数 
        },
        scoreCeil(){
            return parseInt(this.score) % 2  //取余半数星星
        },   
        scoreSurplus(){
            return 5-this.scoreFloor-this.scoreCeil  //剩余
        }
    }
}
</script>
<style scoped>
    img{
        width: 20rpx;
        height: 20rpx;
    }
</style>
方法二

坑点注意:mpvue图片加载src前使用:冒号 等号后面不能使用引号

<template>
    <div>
        <div v-for="(items,key) in start" :key="key">
            <img v-for="(item,keys) in items.numb" :key="keys" :src=items.urls>
        </div>
    </div>
</template>

<script>

export default {
    name:"Score",
    props:["score"],
    data() {
        return {
            start:{}
        }
    },
    created() {
        this.start={
            full:{
                numb:Math.floor(this.score/2),
                urls:'../../static/images/b-star.png'
            },
            half:{
                numb:this.score%2,
                urls:'../../static/images/b-half.png'
            },
            none:{
                numb:5-Math.ceil(this.score/2),
                urls:'../../static/images/gray-star.png'
            }
        }        
    }
}
</script>
<style scoped>
    img{
        width: 20rpx;
        height: 20rpx;
    }
    
</style>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jason–json

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值