下面我就为大家分享一篇vue-star评星组件开发实例,具有很好的参考价值,希望对大家有所帮助。
star文件夹下建立Star.vue,及相关的图片信息。便于组件的就近维护

Star.vue:
<template>
<p class="star" :class="starSize">
<span v-for="(itemClass,key) in itemClasses" :class="itemClass" class="star-item"></span>
</p>
</template>
<script>
const LENGTH = 5;
const CLS_ON = 'on';
const CLS_HALF = 'half';
const CLS_OFF = 'off';
export default{
props:{
size:{ //尺寸,24,36,48
type: Number
},
score:{
type: Number
}
},
computed:{
starSize(){
return 'star-'+ this.size;
},
itemClasses(){
let result = [];
let score = Math.floor(this.score*2)/2; //将数值调整为整数及.5的形式,例:4.3 => 4;4.6 => 4.5
let hasDecimal = score %1 !==0;
let integer = Math.floor(score);
for(let i =0;i<integer;i++){
result.push(CLS_ON);
}
if(hasDecimal){
result.push(CLS_HALF);
}
while(result.length<LENGTH){
result.push(CLS_OFF);
}
return result;
}
}
}
</script>
<style lang="stylus" rel="stylesheet/stylus">
@import "../../common/stylus/mixin.styl";
.star
font-size: 0
.star-item
display: inline-block
background-repeat: no-repeat
&.star-48
.star-item
width: 20px
height: 20px
margin-right: 22px
background-size: 20px 20px
&.last-child
margin-right: 0
&.on
bg-image('star48_on')
&.half
bg-image('star48_half')
&.off
bg-image('star48_off')
&.star-36
.star-item
width: 15px
height: 15px
margin-right: 6px
background-size: 15px 15px
&.last-child
margin-right: 0
&.on
bg-image('star36_on')
&.half
bg-image('star36_half')
&.off
bg-image('star36_off')
&.star-24
.star-item
width: 10px
height: 10px
margin-right: 3px
background-size: 10px 10px
&.last-child
margin-right: 0
&.on
bg-image('star24_on')
&.half
bg-image('star24_half')
&.off
bg-image('star24_off')
</style>Header.vue:
立即学习“前端免费学习笔记(深入)”;
<star :size="48" :score="3.5"></star>
<script>
import star from '../star/Star.vue'
export default{
components:{
star
}
}
</script>mixin.styl:
bg-image($url) background-image: url($url + '@2x.png') @media (-webkit-min-device-pixel-ratio: 3),(min-device-pixel-ratio:3) background-image: url($url + '@3x.png')
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
以上就是在vue-star中如何实现评星组件开发的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号