全部项目

This commit is contained in:
Mr.jiang 2024-08-20 17:29:43 +08:00
parent 80e36d89d0
commit 82fcece4c4
2 changed files with 444 additions and 257 deletions

View File

@ -6,35 +6,50 @@
<view class="service-head-top"> <view class="service-head-top">
<view class="service-head-top-left"> <view class="service-head-top-left">
<image @click="backImg" src="../../static/fanhui.png" mode="widthFix"></image> <image @click="backImg" src="../../static/fanhui.png" mode="widthFix"></image>
<span>更多推荐</span> <span>全部项目</span>
</view> </view>
<view> <view>
<uni-search-bar @service="serviceTrue" @confirm="search" :cancelext="'取消'" v-model="searchValue" @input="input" <uni-search-bar @service="serviceTrue" @confirm="search" :cancelext="'取消'" v-model="searchValue"
@clear="clear"> @input="input" @clear="clear">
</uni-search-bar> </uni-search-bar>
<view class="search-btn" @click="searchBtn"> <view class="search-btn" @click="searchBtn">
<image style="width:30rpx; height:30rpx; margin-right: 10rpx;" src="../../static/search.png"></image> <image style="width:30rpx; height:30rpx; margin-right: 10rpx;"
src="../../static/search.png"></image>
搜索 搜索
</view> </view>
</view> </view>
</view> </view>
<view class="fenlei">
<z-tabs class="z-tabs-fenlei" :list="tabListS" @changeClick="changeClick"/>
</view>
</template> </template>
<!-- <template #refresher="{refresherStatus}" >
<custom-refresher :status="refresherStatus" />
</template> -->
<template #loadingMoreNoMore> <template #loadingMoreNoMore>
<custom-nomore /> <custom-nomore />
</template> </template>
<!-- 右侧商品 -->
<!-- 主体部分 -->
<view class="body">
<!-- 左侧分类 -->
<view class="leftTab">
<scroll-view scroll-y="true" class="tabBox">
<block v-for="(item,index) in tabList" :key="index">
<view class="tabItem" :class="tabCurrent == index?'tabActive':''"
@click="changeTab(index,item)">
{{item.value}}
</view>
</block>
</scroll-view>
</view>
<!-- 右侧商品 -->
<view class="rightGoods">
<!-- <view class="title">{{productTitle}}</view> -->
<view class="item" v-for="(item,index) in dataList" :key="index" @click="itemClick(item)"> <view class="item" v-for="(item,index) in dataList" :key="index" @click="itemClick(item)">
<image :src="item.packageImg" mode="" class="item-img"></image> <image :src="item.packageImg" mode="" class="item-img"></image>
<view class="item-view"> <view class="item-view">
<view class="item-view-title"> <view class="item-view-title">
{{item.title}} {{item.title}}
</view> </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-qian"> <view class="item-view-bottom-qian">
<span></span> <span></span>
<span>{{item.price}}</span> <span>{{item.price}}</span>
@ -56,7 +71,7 @@
</view> </view>
<view class="item-view-bottom"> <view class="item-view-bottom">
<view class="item-view-xiangmu"> <view class="item-view-xiangmu">
<span>已售</span><span>{{item.sales}}</span><!-- | 好评{{item.esteemRate}}% --> <span>已售</span><span>{{item.sales}}</span>
</view> </view>
<view class="item-view-bottom-btn"> <view class="item-view-bottom-btn">
查看 查看
@ -64,6 +79,9 @@
</view> </view>
</view> </view>
</view> </view>
</view>
</view>
</z-paging> </z-paging>
</view> </view>
</template> </template>
@ -72,6 +90,63 @@
export default { export default {
data() { data() {
return { return {
tabListS:[
{
code: "单项",
id: 1,
name: "",
orderNum: 6,
parentId: 22,
remark: "单项",
status: 1,
type: "",
value: "单项",
},
{
code: "套餐",
id: 104,
name: "",
orderNum: 6,
parentId: 22,
remark: "套餐",
status: 1,
type: "",
value: "套餐",
},
{
code: "次卡",
id: 105,
name: "",
orderNum: 6,
parentId: 22,
remark: "次卡",
status: 1,
type: "",
value: "次卡",
},
{
code: "疗程",
id: 106,
name: "",
orderNum: 6,
parentId: 22,
remark: "疗程",
status: 1,
type: "",
value: "疗程",
},
{
code: "企业预约",
id: 114,
name: "",
orderNum: 6,
parentId: 22,
remark: "企业预约",
status: 1,
type: "",
value: "企业预约",
},
],
loadingType: 0, loadingType: 0,
myId: '', myId: '',
// v-model // v-model
@ -85,7 +160,11 @@
limit: 10, limit: 10,
titleNmae: '', titleNmae: '',
classifyId: '', classifyId: '',
tagsData:[] tagsData: [],
//
tabCurrent: 0,
productTitle: '氧气罐',
type:'1'
} }
}, },
onLoad(e) { onLoad(e) {
@ -93,65 +172,54 @@
if (e) { if (e) {
this.searchValue = e.searchValue this.searchValue = e.searchValue
} }
// this.getData() this.tabNav()
}, },
// onPullDownRefresh: function() { // onPullDownRefresh: function() {
// this.page = 1; // this.page = 1;
// this.getData() // this.getData()
// }, // },
methods: { methods: {
changeClick(index,item){
this.type=item.id
this.searchValue=''
this.page = 1;
this.dataList = []
this.getData()
},
tabNav() {
let data = {
type: "服务类型",
}
this.$Request.get('/app/dict/list', data).then(res => {
if (res.code == 0) {
this.tabList = res.data;
this.classifyId=res.data[0].id,
this.productTitle = this.tabList[0].value
this.page = 1;
this.dataList = []
this.getData()
}
})
},
input(res) { // input(res) { //
this.searchValue = res; this.searchValue = res;
}, },
//
// loadMore: async function() {
// //loadingType: 0. 1. 2.
// if(this.loadingType==0){
// this.loadingType=2
// //
// setTimeout(()=>{
// this.page++;
// this.loadingType=0;
// this.getData()
// },1000)
// }
// },
searchBtn() { // searchBtn() { //
if (this.searchValue != "") { if (this.searchValue != "") {
this.getData() this.getData()
} }
}, },
getData() { getData() {
// 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()
// }
// }
// });
this.$refs.paging.reload(true); this.$refs.paging.reload(true);
}, },
// changeClick(index,item){
// this.classifyId=item.id
// this.searchValue=''
// this.getData()
// },
queryList(pageNo, pageSize) { queryList(pageNo, pageSize) {
const params = { const params = {
city: '', city: '',
page: pageNo, page: pageNo,
limit: pageSize, limit: pageSize,
title:this.searchValue title: this.searchValue,
classifyId: this.classifyId,
type:this.type
} }
this.$Request.get('/app/massage/package/findPackageAndMassagePage', params).then(res => { this.$Request.get('/app/massage/package/findPackageAndMassagePage', params).then(res => {
for (var i = 0; i < res.data.list.length; i++) { for (var i = 0; i < res.data.list.length; i++) {
@ -162,6 +230,15 @@
this.$refs.paging.complete(false); this.$refs.paging.complete(false);
}) })
}, },
changeTab(index,item) {
this.tabCurrent = index
this.productTitle = this.tabList[index].value
this.classifyId = item.id
this.searchValue = ''
this.page = 1;
this.dataList = []
this.getData()
},
backImg() { // backImg() { //
uni.reLaunch({ uni.reLaunch({
url: '/pages/index/index' url: '/pages/index/index'
@ -173,19 +250,23 @@
itemClick(item) { itemClick(item) {
if (item.type == '104') { if (item.type == '104') {
uni.navigateTo({ uni.navigateTo({
url:'/pages/my/serviceOderDrtail?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon url: '/pages/my/serviceOderDrtail?id=' + item.id + '&limit=' + this.limit + '&page=' + this
.page + '&name=' + 'index' + '&isCanCoupon=' + item.isCanCoupon
}) })
} else if (item.type == '105') { } else if (item.type == '105') {
uni.navigateTo({ uni.navigateTo({
url:'/pages/my/cikarDrtail?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon url: '/pages/my/cikarDrtail?id=' + item.id + '&limit=' + this.limit + '&page=' + this
.page + '&name=' + 'index' + '&isCanCoupon=' + item.isCanCoupon
}) })
} else if (item.type == '106') { } else if (item.type == '106') {
uni.navigateTo({ uni.navigateTo({
url:'/pages/my/fuwuliaochengDetail?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon url: '/pages/my/fuwuliaochengDetail?id=' + item.id + '&limit=' + this.limit + '&page=' +
this.page + '&name=' + 'index' + '&isCanCoupon=' + item.isCanCoupon
}) })
} else { } else {
uni.navigateTo({ uni.navigateTo({
url:'/pages/my/fuwuDateil?id='+item.id+'&limit='+this.limit+'&page='+this.page+'&name='+'index'+'&isCanCoupon='+item.isCanCoupon url: '/pages/my/fuwuDateil?id=' + item.id + '&limit=' + this.limit + '&page=' + this.page +
'&name=' + 'index' + '&isCanCoupon=' + item.isCanCoupon
}) })
} }
} }
@ -193,12 +274,79 @@
} }
</script> </script>
<style scoped> <style lang="scss" scoped>
/deep/.z-tabs-item-title /deep/span{
white-space: nowrap;
}
.fenlei{
display: flex;
flex-direction: row;
align-items: center;
justify-content: space-between;
}
.body {
height: 100vh;
display: flex;
justify-content: space-between;
.leftTab {
width: 177rpx;
height: 100%;
background: #ffffff;
border-radius: 0px 15rpx 0px 0px;
padding: 24rpx 11rpx;
box-sizing: border-box;
.tabBox {
height: 100%;
.tabItem {
text-align: center;
padding: 14rpx 0;
border-radius: 60rpx;
color: #464646;
font-size: 26rpx;
font-weight: bold;
margin-bottom: 20rpx;
}
.tabActive {
background: #60B347;
color: #ffffff;
}
}
}
.rightGoods {
width: 573rpx;
height: 100%;
padding: 0 16rpx 27rpx;
box-sizing: border-box;
.whiteBox {
height: 100%;
background: #ffffff;
border-radius: 15rpx;
padding: 0 25rpx;
box-sizing: border-box;
.title {
height: 77rpx;
line-height: 77rpx;
color: #2D2D2D;
font-size: 26rpx;
font-weight: bold;
}
}
}
}
.shop_label { .shop_label {
display: flex; display: flex;
flex-wrap: wrap; flex-wrap: wrap;
margin-top: 4rpx; margin-top: 4rpx;
} }
.shop_label span { .shop_label span {
background: linear-gradient(90deg, #ffefde, #fff7ef); background: linear-gradient(90deg, #ffefde, #fff7ef);
height: 34rpx; height: 34rpx;
@ -210,15 +358,18 @@
margin-bottom: 8rpx; margin-bottom: 8rpx;
color: #f68607; color: #f68607;
} }
/deep/.refresh-body { /deep/.refresh-body {
height: 845px !important; height: 845px !important;
background-color: #f7f7f7; background-color: #f7f7f7;
} }
.content-view { .content-view {
width: 100%; width: 100%;
height: 100vh; height: 100vh;
overflow: hidden; overflow: hidden;
} }
.item-view-bottom-btn { .item-view-bottom-btn {
text-align: center; text-align: center;
width: 131rpx; width: 131rpx;
@ -230,31 +381,37 @@
font-size: 28rpx; font-size: 28rpx;
color: #FFFFFF; color: #FFFFFF;
} }
.item-view-bottom-qian span:nth-child(5) { .item-view-bottom-qian span:nth-child(5) {
font-size: 28rpx; font-size: 28rpx;
color: #848484; color: #848484;
text-decoration-line: line-through; text-decoration-line: line-through;
} }
.item-view-bottom-qian span:nth-child(4) { .item-view-bottom-qian span:nth-child(4) {
font-size: 28rpx; font-size: 28rpx;
color: #848484; color: #848484;
text-decoration-line: line-through; text-decoration-line: line-through;
margin-left: 5px; margin-left: 5px;
} }
.item-view-bottom-qian span:nth-child(3) { .item-view-bottom-qian span:nth-child(3) {
font-size: 28rpx; font-size: 28rpx;
color: #FF6000; color: #FF6000;
} }
.item-view-bottom-qian span:nth-child(2) { .item-view-bottom-qian span:nth-child(2) {
font-weight: bold; font-weight: bold;
font-size: 36.81rpx; font-size: 36.81rpx;
color: #FF6000; color: #FF6000;
} }
.item-view-bottom-qian span:nth-child(1) { .item-view-bottom-qian span:nth-child(1) {
font-weight: 400; font-weight: 400;
font-size: 28rpx; font-size: 28rpx;
color: #FF6000; color: #FF6000;
} }
.item-view-bottom-qian { .item-view-bottom-qian {
margin-top: 2px; margin-top: 2px;
} }
@ -266,6 +423,7 @@
justify-content: space-between; justify-content: space-between;
align-items: center; align-items: center;
} }
.item-view-jianjie { .item-view-jianjie {
font-weight: 400; font-weight: 400;
font-size: 24rpx; font-size: 24rpx;
@ -273,41 +431,50 @@
margin: 5px 0px; margin: 5px 0px;
display: -webkit-box; display: -webkit-box;
-webkit-box-orient: vertical; -webkit-box-orient: vertical;
-webkit-line-clamp: 2; /* 显示的行数,可以根据需要修改 */ -webkit-line-clamp: 2;
/* 显示的行数,可以根据需要修改 */
overflow: hidden; overflow: hidden;
text-overflow: ellipsis; text-overflow: ellipsis;
} }
.item-view-biao { .item-view-biao {
padding: 1px 2px; padding: 1px 2px;
border-radius: 6rpx; border-radius: 6rpx;
} }
.tuina { .tuina {
background-color: #d1f2df; background-color: #d1f2df;
color: #17984d; color: #17984d;
} }
.xiaoer { .xiaoer {
background-color: #f1f8d7; background-color: #f1f8d7;
color: #58b314; color: #58b314;
} }
.taishi { .taishi {
background-color: #e5d5c6; background-color: #e5d5c6;
color: #805d39; color: #805d39;
} }
.kangfu { .kangfu {
background-color: #fcf3da; background-color: #fcf3da;
color: #ff8600; color: #ff8600;
} }
.item-view-xiangmu span:nth-child(2) { .item-view-xiangmu span:nth-child(2) {
font-weight: normal; font-weight: normal;
color: #333333; color: #333333;
font-size: 30rpx; font-size: 30rpx;
} }
.item-view-xiangmu span:nth-child(1) { .item-view-xiangmu span:nth-child(1) {
font-weight: normal; font-weight: normal;
color: #666666; color: #666666;
margin-right: 5rpx; margin-right: 5rpx;
font-size: 30rpx; font-size: 30rpx;
} }
.item-view-xiangmu { .item-view-xiangmu {
width: 100%; width: 100%;
display: flex; display: flex;
@ -316,11 +483,13 @@
font-size: 25rpx; font-size: 25rpx;
align-items: flex-end; align-items: flex-end;
} }
.item-view-title { .item-view-title {
font-weight: bold; font-weight: bold;
font-size: 33rpx; font-size: 33rpx;
color: #333333; color: #333333;
} }
.item-view { .item-view {
width: 60%; width: 60%;
height: 100%; height: 100%;
@ -330,12 +499,14 @@
justify-content: space-between; justify-content: space-between;
padding: 5rpx 0; padding: 5rpx 0;
} }
.item-img { .item-img {
width: 240rpx; width: 240rpx;
height: 200rpx; height: 200rpx;
border-radius: 14rpx; border-radius: 14rpx;
position: relative; position: relative;
} }
.img-span { .img-span {
padding: 2px 5px; padding: 2px 5px;
font-weight: 400; font-weight: 400;
@ -349,10 +520,12 @@
margin-bottom: 5px; margin-bottom: 5px;
margin-right: 5px; margin-right: 5px;
} }
.item-img image { .item-img image {
width: 100%; width: 100%;
height: 100%; height: 100%;
} }
.item { .item {
width: 100%; width: 100%;
margin: 0 auto; margin: 0 auto;
@ -366,6 +539,7 @@
align-items: center; align-items: center;
padding: 20rpx; padding: 20rpx;
} }
.item-detail { .item-detail {
padding: 5rpx 15rpx; padding: 5rpx 15rpx;
border-radius: 10rpx; border-radius: 10rpx;
@ -382,20 +556,24 @@
width: 100%; width: 100%;
background-color: #eeeeee; background-color: #eeeeee;
} }
/deep/.zp-paging-container { /deep/.zp-paging-container {
background-color: #f7f7f7; background-color: #f7f7f7;
width: 100%; width: 100%;
} }
/deep/.zp-paging-container-content { /deep/.zp-paging-container-content {
width: 95%; width: 95%;
margin: 0 auto; margin: 0 auto;
} }
.fenlei { .fenlei {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
} }
.index-fenl-title { .index-fenl-title {
width: 81rpx; width: 81rpx;
text-align: center; text-align: center;
@ -407,6 +585,7 @@
font-size: 34rpx; font-size: 34rpx;
color: #019C88; color: #019C88;
} }
.index-fenl-title-bottom { .index-fenl-title-bottom {
position: absolute; position: absolute;
bottom: 0; bottom: 0;
@ -416,9 +595,11 @@
border-radius: 7rpx; border-radius: 7rpx;
background: linear-gradient(-48deg, rgba(1, 156, 136, 0.35), rgba(45, 196, 142, 0.35)); background: linear-gradient(-48deg, rgba(1, 156, 136, 0.35), rgba(45, 196, 142, 0.35));
} }
/deep/.uni-searchbar__cancel { /deep/.uni-searchbar__cancel {
display: none; display: none;
} }
.search-btn { .search-btn {
text-align: center; text-align: center;
color: #019c88; color: #019c88;
@ -430,10 +611,13 @@
display: flex; display: flex;
align-items: center; align-items: center;
} }
/deep/.uni-searchbar__box-icon-search,.search-btn{
/deep/.uni-searchbar__box-icon-search,
.search-btn {
width: 110rpx; width: 110rpx;
height: 50rpx; height: 50rpx;
} }
/deep/.uni-searchbar__box { /deep/.uni-searchbar__box {
height: 34px; height: 34px;
border-radius: 30px !important; border-radius: 30px !important;
@ -444,17 +628,20 @@
flex-flow: row-reverse; flex-flow: row-reverse;
position: relative; position: relative;
} }
/deep/.uni-searchbar { /deep/.uni-searchbar {
width: 250px; width: 250px;
border-radius: 31rpx; border-radius: 31rpx;
padding-right: 24rpx; padding-right: 24rpx;
} }
.service-head-top-left image { .service-head-top-left image {
width: 20px; width: 20px;
height: 20rpx; height: 20rpx;
margin-right: 5px; margin-right: 5px;
margin-left: 10rpx; margin-left: 10rpx;
} }
.service-head-top-left span { .service-head-top-left span {
height: 100rpx; height: 100rpx;
background: url('../../static/images/headline.png') 0rpx 50rpx; background: url('../../static/images/headline.png') 0rpx 50rpx;
@ -465,12 +652,14 @@
display: flex; display: flex;
align-items: center; align-items: center;
} }
.service-head-top-left { .service-head-top-left {
display: flex; display: flex;
flex-direction: row; flex-direction: row;
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
} }
.service-head-top { .service-head-top {
height: 90rpx; height: 90rpx;
display: flex; display: flex;
@ -478,5 +667,4 @@
align-items: center; align-items: center;
justify-content: space-between; justify-content: space-between;
} }
</style> </style>

View File

@ -6,7 +6,7 @@
<view class="service-head-top"> <view class="service-head-top">
<view class="service-head-top-left"> <view class="service-head-top-left">
<image @click="backImg" src="../../static/fanhui.png" mode="widthFix"></image> <image @click="backImg" src="../../static/fanhui.png" mode="widthFix"></image>
<span>服务项目</span> <span>女性专区</span>
</view> </view>
<view> <view>
<uni-search-bar @service="serviceTrue" @confirm="search" :cancelext="'取消'" v-model="searchValue" <uni-search-bar @service="serviceTrue" @confirm="search" :cancelext="'取消'" v-model="searchValue"
@ -98,7 +98,6 @@
// //
tabCurrent: 0, tabCurrent: 0,
productTitle: '氧气罐', productTitle: '氧气罐',
fromStore: false, //
} }
}, },
onLoad() { onLoad() {
@ -449,7 +448,7 @@
} }
.item-view { .item-view {
width: 60%; width: 49%;
height: 100%; height: 100%;
display: flex; display: flex;
flex-direction: column; flex-direction: column;