1. 程式人生 > >vue實現星級評價效果

vue實現星級評價效果

com float exp 分享圖片 lock cor hasd 評價 重新

希望對你們有用,已經自己試過可以的才發布出來的

效果如下:

技術分享圖片

html:

<template>
<div class="evaStar">
<ul class="star">
<li v-for="(itemClass,index) in itemClasses" :class="itemClass" class="star-item" @click="stars(index)" track-by="index"></li><!--性能優化 track-by 數據不改變時不會重新渲染-->
</ul>
</div>
</template>

JS:

<script>
export default{
data(){
return{
score: 4,
}
},
computed:{ //計算屬性
itemClasses(){
let result = []; // 返回的是一個數組,用來遍歷輸出星星
let score = Math.floor(this.score * 2 ) / 2; // 計算所有星星的數量
let hasDecimal = score % 1 !== 0; // 非整數星星判斷
let integer = Math.floor(score); // 整數星星判斷
for(let i=0;i<integer;i++){ // 整數星星使用on
result.push("on"); // 一個整數星星就push一個CLS_ON到數組
}
if(hasDecimal){ // 非整數星星使用half
result.push("half"); // 類似

}
while(result.length < 5){// 余下的用無星星補全,使用off
result.push("off");
}
return result;
}
},
methods:{
stars:function(index){
this.score = index + 1
}
}

}
</script>

CSS:

<style>
.evaStar{
float: right;
padding-top: .34rem;
}
.star{
font-size: 0;
}
.star-item{
display: inline-block;
background-repeat: no-repeat;
width: .6rem;
height: .6rem;
margin-left: .27rem;
background-size: 100%;
}
.star-item.on{
background-image: url(../assets/images/on.png);
}
.star-item.half{
background-image: url(../assets/images/half.png);
}
.star-item.off{
background-image: url(../assets/images/off.png);
}
</style>

vue實現星級評價效果