app/pages/product/shopList.vue

172 lines
3.9 KiB
Vue
Raw Normal View History

2025-03-14 16:27:50 +08:00
<template>
<div>
<u-navbar>
<u-search placeholder="请输入店铺名称" @search="search" @clear="search" @custom="search" v-model="params.storeName">
</u-search>
</u-navbar>
<div class="wrapper" v-if="storeList.length!=0">
<div class="store-item" @click="handleClickStore(item)" v-for="(item,index) in storeList" :key="index">
<div>
2025-03-24 10:53:42 +08:00
<u-image shape="square" width="100" height="100" :src="item.storeLogo">
2025-03-14 16:27:50 +08:00
</u-image>
</div>
<div class="store-msg">
<div class="store-name">
2025-03-24 10:53:42 +08:00
<div> {{item.storeName}}</div>
2025-04-30 14:42:40 +08:00
<div class="typeof" >{{item.selfOperated?'自营':'达人店'}}</div>
2025-03-14 16:27:50 +08:00
</div>
<div class="goods-num">
2025-03-24 10:53:42 +08:00
商品 {{item.goodsNum}} <span class="line">|</span> <span class="store-collection">收藏 {{item.collectionNum}}</span>
2025-03-14 16:27:50 +08:00
</div>
<div class="flex store-distance">
<div>
2025-03-24 10:53:42 +08:00
<template v-for="i in 5">
<u-icon :name="i <= item.serviceScore ? 'star-fill' : 'star'" color="#FF0000" size="30"></u-icon>
</template>
2025-03-14 16:27:50 +08:00
</div>
</div>
</div>
<!--
#TODO 后续将和后端补充从此处
<div class="flex store-goods">
<div class="store-goods-item" v-for="i in 3" :key="i">
<div>
<u-image src="https://picsum.photos/id/341/200/200" border-radius="20" width="215rpx" height="215rpx">
</u-image>
</div>
<div class="price">
<span>
<span class=" goods-price-bigshow">{{ formatPrice(16)[0] }}</span>
.{{ formatPrice(16)[1] }}
</span>
</div>
<div class="wes">test</div>
</div>
</div>
-->
</div>
</div>
<u-empty style="margin-top:20%;" text="暂无店铺信息" v-else></u-empty>
</div>
</template>
<script>
2025-04-30 14:42:40 +08:00
import { getStoreList ,getExpertStoreList} from "@/api/store";
2025-03-14 16:27:50 +08:00
export default {
data() {
return {
keyword: "",
params: {
pageNumber: 1,
pageSize: 10,
storeName: "",
},
storeList: [], // 店铺列表
};
},
onReachBottom() {
this.params.pageNumber++;
this.init();
},
mounted() {
this.init();
},
methods: {
handleClickStore(val){
uni.navigateTo({
url: `/pages/product/shopPage?id=${val.id}`
});
},
search() {
this.storeList = [];
this.init();
},
// 格式化金钱 1999 --> [1999,00]
formatPrice(val) {
if (typeof val == "undefined") {
return val;
}
return val.toFixed(2).split(".");
},
async init() {
2025-04-30 14:42:40 +08:00
let res = await getExpertStoreList(this.params);
2025-03-14 16:27:50 +08:00
if (res.data.success) {
let data = res.data.result;
this.storeList.push(...data.records);
}
},
},
};
</script>
<style lang="scss" scoped>
.wrapper {
padding: 0 16rpx;
}
.store-item {
display: flex;
background: #fff;
border-radius: 20rpx;
margin: 20rpx 0;
padding: 24rpx;
}
.store-msg {
2025-03-24 10:53:42 +08:00
width: 100%;
2025-03-14 16:27:50 +08:00
margin-left: 20rpx;
}
.store-name {
font-weight: bold;
2025-03-24 10:53:42 +08:00
font-size: 35rpx;
display: flex;
justify-content: space-between;
.typeof{
border: 1px solid red;
color: red;
font-size: 30rpx;
}
2025-03-14 16:27:50 +08:00
}
.goods-num,
.store-collection {
color: #999;
font-size: 24rpx;
line-height: 1.5;
}
.store-goods {
margin: 20rpx 0;
}
.store-goods-item {
flex: 1;
overflow: hidden;
display: flex;
justify-content: flex-start;
flex-direction: column;
margin: 0 5rpx;
}
.wes {
margin: 10rpx 0;
width: 100%;
}
.store-score {
color: $light-color;
font-size: 24rpx;
font-weight: bold;
}
.line {
margin: 0 6rpx;
color: #999;
}
.store-distance {
justify-content: space-between;
}
.price {
margin-top: 10rpx;
color: $main-color;
}
.goods-price-bigshow {
font-size: 34rpx;
font-weight: bold;
}
</style>