You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
112 lines
3.4 KiB
112 lines
3.4 KiB
<template> |
|
<view class="evaluate-list" ref="container"> |
|
<view class="header"> |
|
<view class="generalComment acea-row row-between-wrapper"> |
|
<view class="acea-row row-middle font-color-red"> |
|
<text class="evaluate">评分</text> |
|
<view class="start" :class="'star' + replyData.replyStar"></view> |
|
</view> |
|
<view> |
|
<text class="font-color-red">{{ replyData.replyChance || 0 }}%</text> |
|
<text>好评率</text> |
|
</view> |
|
</view> |
|
<view class="nav acea-row row-middle"> |
|
<view |
|
class="acea-row row-center-wrapper" |
|
v-for="(item, navListIndex) in navList" |
|
:key="navListIndex" |
|
@click="changeType(navListIndex)" |
|
> |
|
<view |
|
class="item" |
|
:class="currentActive === navListIndex ? 'bg-color-red' : ''" |
|
v-if="item.num" |
|
> |
|
<text>{{ item.evaluate }}({{ item.num }})</text> |
|
</view> |
|
</view> |
|
</view> |
|
</view> |
|
<UserEvaluation :reply="reply"></UserEvaluation> |
|
<Loading :loaded="loadend" :loading="loading"></Loading> |
|
</view> |
|
</template> |
|
<script> |
|
import UserEvaluation from "@/components/UserEvaluation"; |
|
import { getReplyConfig, getReplyList } from "@/api/store"; |
|
import Loading from "@/components/Loading"; |
|
|
|
export default { |
|
name: "EvaluateList", |
|
components: { |
|
UserEvaluation, |
|
Loading |
|
}, |
|
props: {}, |
|
data: function() { |
|
return { |
|
product_id: 0, |
|
replyData: {}, |
|
navList: [ |
|
{ evaluate: "全部", num: 0 }, |
|
{ evaluate: "好评", num: 0 }, |
|
{ evaluate: "中评", num: 0 }, |
|
{ evaluate: "差评", num: 0 } |
|
], |
|
currentActive: 0, |
|
page: 1, |
|
limit: 8, |
|
reply: [], |
|
loadTitle: "", |
|
loading: false, |
|
loadend: false |
|
}; |
|
}, |
|
mounted: function() { |
|
this.product_id = this.$yroute.query.id; |
|
this.getProductReplyCount(); |
|
this.getProductReplyList(); |
|
}, |
|
onReachBottom() { |
|
!this.loading && this.getProductReplyList(); |
|
}, |
|
methods: { |
|
getProductReplyCount () { |
|
getReplyConfig(this.product_id).then(res => { |
|
this.$set(that, "replyData", res.data); |
|
this.navList[0].num = res.data.sumCount; |
|
this.navList[1].num = res.data.goodCount; |
|
this.navList[2].num = res.data.inCount; |
|
this.navList[3].num = res.data.poorCount; |
|
}); |
|
}, |
|
getProductReplyList () { |
|
if (this.loading) return; //阻止下次请求(false可以进行请求); |
|
if (this.loadend) return; //阻止结束当前请求(false可以进行请求); |
|
this.loading = true; |
|
let q = { page: this.page, limit: this.limit, type: this.currentActive }; |
|
getReplyList(this.product_id, q).then(res => { |
|
this.loading = false; |
|
//apply();js将一个数组插入另一个数组; |
|
this.reply.push.apply(this.reply, res.data); |
|
this.loadend = res.data.length < this.limit; //判断所有数据是否加载完成; |
|
this.page = this.page + 1; |
|
}); |
|
}, |
|
changeType (index) { |
|
this.currentActive = index; |
|
this.page = 1; |
|
this.loadend = false; |
|
this.$set(this, "reply", []); |
|
this.getProductReplyList(); |
|
} |
|
} |
|
}; |
|
</script> |
|
<style scoped lang="less"> |
|
.noCommodity { |
|
height: 8*100rpx; |
|
background-color: #fff; |
|
} |
|
</style>
|
|
|