最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

在vue-star中如何实现评星组件开发

来源:动视网 责编:小OO 时间:2020-11-27 19:41:40
文档

在vue-star中如何实现评星组件开发

star文件夹下建立Star.vue,及相关的图片信息。便于组件的就近维护。Star.vue。,<;template>;<;p class=";star";:class=";starSize";>;<;span v-for=";(itemClass,24,36。Header.vue。
推荐度:
导读star文件夹下建立Star.vue,及相关的图片信息。便于组件的就近维护。Star.vue。,<;template>;<;p class=";star";:class=";starSize";>;<;span v-for=";(itemClass,24,36。Header.vue。
 下面我就为大家分享一篇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使用 分享示例

200行代码实现blockchain 区块链实例详解

react以create-react-app为基础创建项目

文档

在vue-star中如何实现评星组件开发

star文件夹下建立Star.vue,及相关的图片信息。便于组件的就近维护。Star.vue。,<;template>;<;p class=";star";:class=";starSize";>;<;span v-for=";(itemClass,24,36。Header.vue。
推荐度:
标签: VUE 组件 star
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top