sadjv3_user/pages/my/fuwuGengduo.vue

477 lines
12 KiB
Vue
Raw Normal View History

2024-06-24 11:29:11 +08:00
<!-- 自定义下拉刷新与上拉加载演示(vue) -->
<template>
<view class="content-view">
2024-07-25 20:58:11 +08:00
<z-paging ref="paging" v-model="dataList" @query="queryList" >
<template #top>
<view class="service-head-top">
<view class="service-head-top-left">
<image @click="backImg" src="../../static/fanhui.png" mode="widthFix"></image>
<span>更多推荐</span>
</view>
<view>
<uni-search-bar @service="serviceTrue" @confirm="search" :cancelext="'取消'" v-model="searchValue" @input="input"
@clear="clear">
</uni-search-bar>
<view class="search-btn" @click="searchBtn">
搜索
</view>
</view>
</view>
</template>
2024-07-26 10:45:31 +08:00
<!-- <template #refresher="{refresherStatus}" >
2024-07-25 20:58:11 +08:00
<custom-refresher :status="refresherStatus" />
2024-07-26 10:45:31 +08:00
</template> -->
2024-07-25 20:58:11 +08:00
<template #loadingMoreNoMore >
<custom-nomore />
</template>
<view class="item" v-for="(item,index) in dataList" :key="index" @click="itemClick(item)">
<image :src="item.packageImg" mode="" class="item-img"></image>
<view class="item-view">
<view class="item-view-title">
{{item.title}}
</view>
<!-- <view class="item-view-xiangmu">
<span class="xiaoer item-view-biao">{{item.classifyName}}</span>
<span>已售{{item.sales}} | 好评{{item.esteemRate}}%</span>
</view> -->
<view class="item-view-bottom">
<view class="item-view-bottom-qian">
<span></span>
<span>{{item.price}}</span>
<span v-if="item.type!='104'">
2024-07-15 16:30:27 +08:00
/{{item.serviceCount?item.serviceCount:''}}{{item.type=='105'||item.type=='106'?'':''}}
2024-07-13 10:04:42 +08:00
</span>
2024-07-25 20:58:11 +08:00
<span v-if="item.type=='104'">/
2024-07-13 10:04:42 +08:00
</span>
2024-07-25 20:58:11 +08:00
<span v-if="item.type!='104'">{{item.oldPrice}}/{{item.serviceCount?item.serviceCount:''}}{{item.type=='105'||item.type=='106'?'':''}}</span>
<span v-if="item.type=='104'">{{item.oldPrice}}/</span>
</view>
</view>
<view class="shop_label" v-if="item.tagsData!=''">
<span v-for="tag in item.tagsData" :key="tag">{{tag}}</span>
</view>
<view class="shop_label" v-else>
<span>助眠解压</span>
</view>
<view class="item-view-bottom">
<view class="item-view-xiangmu">
<span>已售</span><span>{{item.sales}}</span><!-- | 好评{{item.esteemRate}}% -->
</view>
<view class="item-view-bottom-btn">
查看
</view>
</view>
</view>
</view>
</z-paging>
2024-06-24 11:29:11 +08:00
</view>
</template>
<script>
export default {
data() {
return {
loadingType:0,
myId: '',
// v-model绑定的这个变量不要在分页请求结束中自己赋值
dataList: [],
tabList: [],
typeData:'105',
tabIndex: 0,
searchValue:'',
serviceTrue:true,
page:1,
limit:10,
titleNmae:'',
2024-07-13 14:21:23 +08:00
classifyId:'',
tagsData:[]
2024-06-24 11:29:11 +08:00
}
},
2024-07-10 17:58:14 +08:00
onLoad(e){
2024-06-24 11:29:11 +08:00
this.myId = uni.getStorageSync('userId')
2024-07-10 17:58:14 +08:00
if(e){
this.searchValue=e.searchValue
}
2024-07-25 20:58:11 +08:00
// this.getData()
2024-06-24 11:29:11 +08:00
},
2024-07-25 20:58:11 +08:00
// onPullDownRefresh: function() {
// this.page = 1;
// this.getData()
// },
2024-06-24 11:29:11 +08:00
methods: {
2024-07-25 20:58:11 +08:00
input(res) {//搜索 输入框
this.searchValue=res;
},
2024-06-24 11:29:11 +08:00
// 加载更多
2024-07-25 20:58:11 +08:00
// loadMore: async function() {
// //loadingType: 0.数据未加载完 1.数据全部加载完了 2.数据加载中
// if(this.loadingType==0){
// this.loadingType=2
// //模拟数据请求
// setTimeout(()=>{
// this.page++;
// this.loadingType=0;
// this.getData()
// },1000)
// }
// },
2024-06-24 11:29:11 +08:00
searchBtn(){//搜索按钮
if(this.searchValue!=""){
this.getData()
}
},
getData(){
2024-07-25 22:31:49 +08:00
// this.$Request.get("/app/massage/package/findPackageAndMassagePage",{
// city:'',
// page:this.page,
// limit:this.limit,
// title:this.searchValue
// }).then(res => {
// if (res.code == 0) {
// if (res.data) {
// if (this.page == 1) this.dataList = []; //如果是第一页需手动制空列表
// this.dataList = [...this.dataList, ...res.data.list]; //追加新数据
// for(var i=0;i<this.dataList.length;i++){
// this.dataList[i].tagsData=this.dataList[i].labels.split(',');
// }
// uni.stopPullDownRefresh()
// }
// }
// });
2024-07-25 20:58:11 +08:00
this.$refs.paging.reload(true);
2024-06-24 11:29:11 +08:00
},
2024-07-25 20:58:11 +08:00
// changeClick(index,item){
// this.classifyId=item.id
// this.searchValue=''
// this.getData()
// },
queryList(pageNo, pageSize) {
const params = {
city:'',
page:pageNo,
limit:pageSize,
title:this.searchValue
}
this.$Request.get('/app/massage/package/findPackageAndMassagePage',params).then(res => {
for(var i=0;i<res.data.list.length;i++){
res.data.list[i].tagsData=res.data.list[i].labels.split(',');
}
this.$refs.paging.complete(res.data.list);
}).catch(res => {
this.$refs.paging.complete(false);
})
},
2024-06-24 11:29:11 +08:00
backImg(){//返回上一页
uni.reLaunch({
url:'/pages/index/index'
})
2024-07-25 20:58:11 +08:00
},
2024-06-24 11:29:11 +08:00
clear(res) {
this.getData()
},
itemClick(item) {
if(item.type=='104'){
uni.navigateTo({
url:'/pages/my/serviceOderDrtail?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon
})
}else if(item.type=='105'){
uni.navigateTo({
url:'/pages/my/cikarDrtail?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon
})
}else if(item.type=='106'){
uni.navigateTo({
url:'/pages/my/fuwuliaochengDetail?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon
})
}else{
uni.navigateTo({
url:'/pages/my/fuwuDateil?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon
})
}
2024-07-25 20:58:11 +08:00
2024-06-24 11:29:11 +08:00
}
}
}
</script>
<style scoped>
2024-07-13 14:21:23 +08:00
.shop_label{
display: flex;
flex-wrap: wrap;
2024-07-24 14:37:55 +08:00
margin-top: 10rpx;
2024-07-13 14:21:23 +08:00
}
.shop_label span{
2024-07-25 19:36:32 +08:00
background: linear-gradient(90deg, #ffefde, #fff7ef);
2024-07-24 14:37:55 +08:00
height: 34rpx;
line-height: 34rpx;
2024-07-13 14:21:23 +08:00
border-radius: 8rpx;
2024-07-24 14:37:55 +08:00
padding: 0 10rpx;
font-size: 22rpx;
2024-07-13 14:21:23 +08:00
margin-right: 8rpx;
margin-bottom: 8rpx;
2024-07-25 19:36:32 +08:00
color: #f68607;
2024-07-13 14:21:23 +08:00
}
2024-06-24 11:29:11 +08:00
/deep/.refresh-body{
2024-07-04 19:13:27 +08:00
height: 845px !important;
2024-06-24 11:29:11 +08:00
background-color: #f7f7f7;
}
.content-view{
width: 100%;
height: 100vh;
2024-07-04 19:13:27 +08:00
overflow: hidden;
2024-06-24 11:29:11 +08:00
}
.item-view-bottom-btn{
text-align: center;
width: 131rpx;
2024-07-25 19:36:32 +08:00
height: 55rpx;
line-height: 55rpx;
2024-06-24 11:29:11 +08:00
background: linear-gradient(90deg, #019C88, #0FA78B, #35C495);
border-radius: 10rpx;
font-weight: bold;
2024-07-25 19:36:32 +08:00
font-size: 28rpx;
2024-06-24 11:29:11 +08:00
color: #FFFFFF;
}
.item-view-bottom-qian span:nth-child(4){
2024-07-25 19:36:32 +08:00
font-size: 26rpx;
color: #848484;
text-decoration-line: line-through;
margin-left: 5px;
2024-06-24 11:29:11 +08:00
}
.item-view-bottom-qian span:nth-child(1){
2024-07-25 19:36:32 +08:00
font-weight: 400;
font-size: 26rpx;
color: #F95900;
2024-06-24 11:29:11 +08:00
}
.item-view-bottom-qian span:nth-child(2){
2024-07-25 19:36:32 +08:00
font-weight: bold;
font-size: 36.81rpx;
color: #FF1200;
2024-06-24 11:29:11 +08:00
}
.item-view-bottom-qian span:nth-child(3){
2024-07-25 19:36:32 +08:00
font-size: 26rpx;
color: #FF1200;
2024-06-24 11:29:11 +08:00
}
.item-view-bottom{
width: 100%;
display: flex;
flex-direction: row;
justify-content: space-between;
align-items: center;
2024-07-03 13:41:18 +08:00
margin-top: 12rpx;
2024-06-24 11:29:11 +08:00
}
.item-view-jianjie{
font-weight: 400;
2024-07-03 13:41:18 +08:00
font-size: 24rpx;
2024-06-24 11:29:11 +08:00
color: #848484;
margin:5px 0px;
display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 2; /* 显示的行数,可以根据需要修改 */
overflow: hidden;
text-overflow: ellipsis;
}
.item-view-biao{
padding: 1px 2px;
border-radius: 6rpx;
}
.tuina{
background-color:#d1f2df;
color: #17984d;
}
.xiaoer{
background-color:#f1f8d7;
color: #58b314;
}
.taishi{
background-color:#e5d5c6;
color: #805d39;
}
.kangfu{
background-color:#fcf3da;
color: #ff8600;
}
2024-07-04 14:03:51 +08:00
.item-view-xiangmu span:nth-child(2){
2024-06-24 11:29:11 +08:00
font-weight: normal;
color: #666666;
2024-07-04 14:03:51 +08:00
}
.item-view-xiangmu span:nth-child(1){
font-weight: normal;
color: #999;
margin-right: 5rpx;
2024-06-24 11:29:11 +08:00
}
.item-view-xiangmu{
width: 100%;
display: flex;
flex-direction: row;
font-weight: 400;
2024-07-04 14:03:51 +08:00
font-size: 25rpx;
align-items: flex-end;
2024-06-24 11:29:11 +08:00
}
.item-view-title{
font-weight: bold;
font-size: 33rpx;
color: #333333;
}
.item-view{
width: 55%;
height: 100%;
display: flex;
flex-direction: column;
justify-content: center;
}
.item-img{
width: 285rpx;
height: 120px;
border-radius: 14rpx;
position: relative;
}
.img-span{
padding: 2px 5px;
font-weight: 400;
font-size: 8px;
color: #FFFFFF;
background: linear-gradient(-90deg, #FF6F48, #FF9E69);
border-radius: 7px 0px 7px 0px;
position: absolute;
bottom: 0px;
right: 0;
margin-bottom: 5px;
margin-right: 5px;
}
.item-img image{
width: 100%;
height: 100%;
}
.item {
2024-07-25 20:58:11 +08:00
width: 96%;
margin: 0 auto;
display: flex;
flex-direction: row;
justify-content: space-between;
height: 140px;
background: #FFFFFF;
border-radius: 21rpx;
margin-top:10px;
align-items: center;
padding: 12px;
2024-06-24 11:29:11 +08:00
}
2024-07-25 20:58:11 +08:00
2024-06-24 11:29:11 +08:00
.item-detail {
padding: 5rpx 15rpx;
border-radius: 10rpx;
font-size: 28rpx;
color: white;
background-color: #007AFF;
}
2024-07-25 20:58:11 +08:00
2024-06-24 11:29:11 +08:00
.item-line {
position: absolute;
bottom: 0rpx;
left: 0rpx;
height: 1px;
width: 100%;
background-color: #eeeeee;
}
/deep/.zp-paging-container{
background-color: #f7f7f7;
width:100%;
}
/deep/.zp-paging-container-content{
2024-07-25 20:58:11 +08:00
width: 100%;
2024-06-24 11:29:11 +08:00
margin: 0 auto;
}
.fenlei{
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between;
}
.index-fenl-title{
width: 81rpx;
text-align: center;
position: relative;
display: flex;
flex-direction: column;
align-items: center;
font-weight: bold;
font-size: 34rpx;
color:#019C88;
}
.index-fenl-title-bottom{
position: absolute;
bottom: 0;
margin-bottom: 0px;
width: 81rpx;
height: 14rpx;
border-radius: 7rpx;
background: linear-gradient(-48deg,rgba(1, 156, 136, 0.35),rgba(45, 196, 142, 0.35));
}
/deep/.uni-searchbar__cancel{
display: none;
}
.search-btn{
2024-07-24 14:37:55 +08:00
text-align: center;
line-height: 56rpx;
color: #fff;
position: absolute;
right:30rpx;
top: 22rpx;
height: 56rpx !important;
2024-06-24 11:29:11 +08:00
}
/deep/.uni-searchbar__box-icon-search,.search-btn{
2024-07-23 22:34:46 +08:00
width: 110rpx;
height: 50rpx;
2024-06-24 11:29:11 +08:00
background: #18A689;
border-radius: 31rpx;
}
/deep/.uni-searchbar__box{
2024-07-23 22:34:46 +08:00
height: 30px;
border-radius: 30px !important;
2024-06-24 11:29:11 +08:00
background-color: #fff !important;
2024-07-23 22:34:46 +08:00
border: 1px solid #09a28a;
2024-06-24 11:29:11 +08:00
display: flex;
flex-direction: row;
flex-flow: row-reverse;
position: relative;
}
/deep/.uni-searchbar{
2024-07-23 22:34:46 +08:00
width: 230px;
2024-06-24 11:29:11 +08:00
border-radius: 31rpx;
2024-07-24 14:37:55 +08:00
margin-right: 20rpx;
2024-06-24 11:29:11 +08:00
}
.service-head-top-left image{
2024-07-23 22:34:46 +08:00
width: 20px;
height: 20rpx;
margin-right:5px;
margin-left: 10rpx;
2024-06-24 11:29:11 +08:00
}
.service-head-top-left span{
2024-07-24 14:37:55 +08:00
height:100rpx;
background:url('../../static/images/headline.png') 0rpx 50rpx;
2024-07-23 22:34:46 +08:00
background-repeat: no-repeat;
2024-06-24 11:29:11 +08:00
font-weight: bold;
2024-07-03 12:15:39 +08:00
font-size: 34rpx;
2024-06-24 11:29:11 +08:00
color: #171717;
2024-07-24 14:37:55 +08:00
display: flex;
align-items: center;
2024-06-24 11:29:11 +08:00
}
.service-head-top-left{
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between;
}
.service-head-top{
width: 100%;
2024-07-24 14:37:55 +08:00
height: 100rpx;
2024-06-24 11:29:11 +08:00
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between;
2024-07-24 14:37:55 +08:00
background: linear-gradient(60deg,rgba(115, 212, 183, 0.2),rgba(227, 251, 244, 0.1),rgba(193, 236, 223, 0.35));
border-bottom:1rpx solid #c4ede1;
2024-06-24 11:29:11 +08:00
}
2024-07-25 20:58:11 +08:00
2024-06-24 11:29:11 +08:00
</style>