ホームページ > ウェブフロントエンド > jsチュートリアル > vue-star で星評価コンポーネント開発を実装する方法

vue-star で星評価コンポーネント開発を実装する方法

亚连
リリース: 2018-06-02 14:46:52
オリジナル
1992 人が閲覧しました

ここで、参考値として優れた 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 = &#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;)
ログイン後にコピー

上記は私がしたものです皆さんのためにまとめましたので、今後皆さんのお役に立てれば幸いです。

関連記事:

vue は Facebook twitter を使用して例を共有します

ブロックチェーンを実装するための 200 行のコード ブロックチェーンの例の詳細な説明

react は create-react-app に基づいてプロジェクトを作成します

以上がvue-star で星評価コンポーネント開発を実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート