本篇是星星評分部分,先上代碼:vue
1.header.vue:app
<template>
<transition name="fade">
<div v-show="detailShow" class="detail">
<div class="detail-wrapper clearfix">
<div class="detail-main">
<h1 class="name">{{seller.name}}</h1>
<div class="star-wrapper">
<star :size="48" :score = "seller.score"></star> <!--忽略其餘,紅色部分爲星星評分有效代碼,這裏是使用星星組件,而且這裏綁定了size和score,使得在star.vue裏也能取到。
</div>
<div class="title">
<div class="line"></div>
<div class="text">優惠信息</div>
<div class="line"></div>
</div>
<ul v-if="seller.supports" class="supports">
<li class="support-item" v-for="(item,index) in seller.supports">
<span class="icon" :class="classMap[seller.supports[index].type]"></span>
<span class="text">{{seller.supports[index].description}}</span>
</li>
</ul>
<div class="title">
<div class="line"></div>
<div class="text">商家公告</div>
<div class="line"></div>
</div>
<div class="bulletin">
<p class="content">{{seller.bulletin}}</p>
</div>
</div>
</div>
<div class="detail-close" @click="hideDetail">
<i class="icon-close">*</i>
</div>
</div>
</transition>
</template>
<script> import star from 'components/star/star'; <!-----忽略其餘,紅色部分爲星星評分有效代碼,這裏是引入星星組件 export default{ props:{ seller:{ type:Object } }, data(){ return { detailShow:false }; }, methods:{ showDetail(){ this.detailShow = true; }, hideDetail(){ this.detailShow = false; } }, created() { this.classMap = ['decrease','discount','special','invoice','guarantee']; }, components:{ <!-----忽略其餘,紅色部分爲星星評分有效代碼,這裏加入星星組件做爲header的子組件。 star } } </script>
2.star.vue:less
<template> <div class="star" :class="starType"> <span v-for="itemClass in itemClasses" :class="itemClass" class="star-item" track-by ="$index"></span> <!-- v-for="(itemClass,index) in itemClasses" --> </div> </template> <script> const LENGTH = 5; const CLS_ON = 'on'; const CLS_HALF = 'half'; const CLS_OFF = 'off'; export default{ props:{ size:{ type:Number }, score:{ type:Number } }, computed:{ starType(){ return 'star-'+this.size; }, itemClasses(){ let result = []; let score = Math.floor(this.score *2) /2;// 經過分數算星星個數 // 向下取0.5的公式。floor() 執行向下取整 // floor(3.3 * 2) / 2 = 3 即 3顆全星+2顆無星 // floor(3.6 * 2) / 2 = 3.5 即 3顆全星+1顆半星+1顆無星 let hasDecimal = score % 1 !== 0;// 取餘不爲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='less'> @import "../../common/style/mixin.less"; .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_on') } &.off{ .bg-image('star36_on') } } } &.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_on') } &.off{ .bg-image('star24_on') } } } } </style>