Home >Web Front-end >JS Tutorial >How to implement star rating component development in vue-star

How to implement star rating component development in vue-star

亚连
亚连Original
2018-06-02 14:46:521972browse

Now I will share with you a vue-star star rating component development example, which has a good reference value and I hope it will be helpful to everyone.

Create Star.vue and related picture information in the star folder. Convenient for nearby maintenance of components

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 = &#39;on&#39;;
 const CLS_HALF = &#39;half&#39;;
 const CLS_OFF = &#39;off&#39;;
 export default{
 props:{
  size:{ //尺寸,24,36,48
  type: Number
  },
  score:{
  type: Number
  }
 },
 computed:{
  starSize(){
  return &#39;star-&#39;+ 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(&#39;star48_on&#39;)
  &.half
  bg-image(&#39;star48_half&#39;)
  &.off
  bg-image(&#39;star48_off&#39;)
 &.star-36
 .star-item
  width: 15px
  height: 15px
  margin-right: 6px
  background-size: 15px 15px
  &.last-child
  margin-right: 0
  &.on
  bg-image(&#39;star36_on&#39;)
  &.half
  bg-image(&#39;star36_half&#39;)
  &.off
  bg-image(&#39;star36_off&#39;)
 &.star-24
 .star-item
  width: 10px
  height: 10px
  margin-right: 3px
  background-size: 10px 10px
  &.last-child
  margin-right: 0
  &.on
  bg-image(&#39;star24_on&#39;)
  &.half
  bg-image(&#39;star24_half&#39;)
  &.off
  bg-image(&#39;star24_off&#39;)
</style>

Header .vue:

<star :size="48" :score="3.5"></star>
<script>
import star from &#39;../star/Star.vue&#39;
export default{
 components:{
 star
 }
}
</script>

mixin.styl:

bg-image($url)
 background-image: url($url + &#39;@2x.png&#39;)
 @media (-webkit-min-device-pixel-ratio: 3),(min-device-pixel-ratio:3)
 background-image: url($url + &#39;@3x.png&#39;)

The above is what I compiled for everyone, I hope it will be better in the future Helpful to everyone.

Related articles:

vue uses facebook twitter to share examples

##200 lines of code to implement blockchain Detailed explanation of blockchain examples

react creates a project based on create-react-app

The above is the detailed content of How to implement star rating component development in vue-star. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn