perf: 🎨 改善促销部分荣誉代码 封装为组件使用 更加便捷以及好看。 优化部分页面显示问题
删除部分原有的老样式 更新新版促销样式 页面更加好看 删除冗余代码 封装多种方法以及组件master
							parent
							
								
									8c8522c68e
								
							
						
					
					
						commit
						1e9df74034
					
				
							
								
								
									
										4
									
								
								App.vue
								
								
								
								
							
							
						
						
									
										4
									
								
								App.vue
								
								
								
								
							|  | @ -189,7 +189,7 @@ | ||||||
| 										url: path, | 										url: path, | ||||||
| 									}); | 									}); | ||||||
| 								} else { | 								} else { | ||||||
| 									this.$navigateTo({ | 									uni.navigateTo({ | ||||||
| 										url: path, | 										url: path, | ||||||
| 									}); | 									}); | ||||||
| 								} | 								} | ||||||
|  | @ -214,7 +214,7 @@ | ||||||
| 								url: `/${path}`, | 								url: `/${path}`, | ||||||
| 							}); | 							}); | ||||||
| 						} else { | 						} else { | ||||||
| 							this.$navigateTo({ | 							uni.navigateTo({ | ||||||
| 								url: `/${path}`, | 								url: `/${path}`, | ||||||
| 							}); | 							}); | ||||||
| 						} | 						} | ||||||
|  |  | ||||||
|  | @ -263,7 +263,7 @@ | ||||||
| 			buy(data) { | 			buy(data) { | ||||||
| 				API_trade.addToCart(data).then((res) => { | 				API_trade.addToCart(data).then((res) => { | ||||||
| 					if (res.data.success) { | 					if (res.data.success) { | ||||||
| 						this.$navigateTo({ | 						uni.navigateTo({ | ||||||
| 							url: `/pages/order/fillorder?way=${ | 							url: `/pages/order/fillorder?way=${ | ||||||
|               data.cartType |               data.cartType | ||||||
|             }&addr=${""}&parentOrder=${encodeURIComponent( |             }&addr=${""}&parentOrder=${encodeURIComponent( | ||||||
|  | @ -314,7 +314,7 @@ | ||||||
| 
 | 
 | ||||||
| 					API_trade.addToCart(data).then((res) => { | 					API_trade.addToCart(data).then((res) => { | ||||||
| 						if (res.data.code == 200) { | 						if (res.data.code == 200) { | ||||||
| 							this.$navigateTo({ | 							uni.navigateTo({ | ||||||
| 								url: `/pages/order/fillorder?way=${data.cartType}&addr=${ | 								url: `/pages/order/fillorder?way=${data.cartType}&addr=${ | ||||||
|                 this.addr.id || "" |                 this.addr.id || "" | ||||||
|               }&parentOrder=${encodeURIComponent(JSON.stringify(this.parentOrder))}`, |               }&parentOrder=${encodeURIComponent(JSON.stringify(this.parentOrder))}`, | ||||||
|  |  | ||||||
|  | @ -0,0 +1,160 @@ | ||||||
|  | <template> | ||||||
|  | 	<div> | ||||||
|  | 		<div v-for="(item, index) in res" :key="index" class="goods-row" @click="navigateToDetailPage(item)"> | ||||||
|  | 			<div class="flex goods-col"> | ||||||
|  | 				<div class="goods-img"> | ||||||
|  | 					<u-image width="230rpx" border-radius='16' height="230rpx" :src="item.goodsImage || item.thumbnail"> | ||||||
|  | 						<u-loading slot="loading"></u-loading> | ||||||
|  | 					</u-image> | ||||||
|  | 				</div> | ||||||
|  | 				<div class="goods-detail"> | ||||||
|  | 					<div class="title clamp3">{{ item.goodsName }}</div> | ||||||
|  | 					<div class='flex flex-a-c flex-j-sb'> | ||||||
|  | 						<view class="price-box"> | ||||||
|  | 							<!-- 秒杀 / 拼团 --> | ||||||
|  | 							<div class="price" v-if="!type && item.price!=undefined"> | ||||||
|  | 								¥<span>{{ formatPrice(item.price )[0] }} </span>.{{ | ||||||
|  | 										formatPrice(item.price )[1] | ||||||
|  | 									}} | ||||||
|  | 							</div> | ||||||
|  | 							<!-- 砍价 --> | ||||||
|  | 							<div class="price" v-if="type && item.purchasePrice!=undefined"> | ||||||
|  | 								最低: | ||||||
|  | 								¥<span>{{ formatPrice(item.purchasePrice )[0] }} </span>.{{ | ||||||
|  | 										formatPrice(item.purchasePrice )[1] | ||||||
|  | 									}} | ||||||
|  | 							</div> | ||||||
|  | 						</view> | ||||||
|  | 						<div> | ||||||
|  | 							<image class='buy' :src="buy"></image> | ||||||
|  | 						</div> | ||||||
|  | 					</div> | ||||||
|  | 					<div class='count-config' v-if="!type"> | ||||||
|  | 						<span>即将恢复{{ item.originalPrice}}元</span> | ||||||
|  | 					</div> | ||||||
|  | 				</div> | ||||||
|  | 			</div> | ||||||
|  | 
 | ||||||
|  | 		</div> | ||||||
|  | 	</div> | ||||||
|  | </template> | ||||||
|  | 
 | ||||||
|  | <script> | ||||||
|  | 	import commonTpl from '@/components/m-goods-list/common' | ||||||
|  | 	export default { | ||||||
|  | 		data() { | ||||||
|  | 			return { | ||||||
|  | 				lightColor: this.$mainColor, | ||||||
|  | 				buy: require('@/static/buy.png') | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		mixins: [commonTpl], | ||||||
|  | 		props: { | ||||||
|  | 			// 遍历的数据 | ||||||
|  | 			res: { | ||||||
|  | 				type: Array, | ||||||
|  | 				default: () => { | ||||||
|  | 					return [] | ||||||
|  | 				} | ||||||
|  | 			}, | ||||||
|  | 			type:{ | ||||||
|  | 				type:null, | ||||||
|  | 				default:"" | ||||||
|  | 			} | ||||||
|  | 		}, | ||||||
|  | 		methods: { | ||||||
|  | 			// 跳转到商品详情 | ||||||
|  | 			navigateToDetailPage(item) { | ||||||
|  | 				uni.navigateTo({ | ||||||
|  | 					url: `/pages/product/goods?id=${item.skuId}&goodsId=${item.goodsId}`, | ||||||
|  | 				}); | ||||||
|  | 			}, | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </script> | ||||||
|  | 
 | ||||||
|  | <style lang='scss' scoped> | ||||||
|  | 	.buy { | ||||||
|  | 		width: 152rpx; | ||||||
|  | 		height: 108rpx; | ||||||
|  | 	} | ||||||
|  | 	.flex-j-sb { | ||||||
|  | 		width: 100%; | ||||||
|  | 	} | ||||||
|  | 	.goods-row { | ||||||
|  | 		background: #fff; | ||||||
|  | 		padding: 16rpx; | ||||||
|  | 		>.goods-col { | ||||||
|  | 			display: flex; | ||||||
|  | 			>.goods-img { | ||||||
|  | 				overflow: hidden; | ||||||
|  | 				flex: 4; | ||||||
|  | 			} | ||||||
|  | 			>.goods-detail { | ||||||
|  | 				flex: 7; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	.goods-detail { | ||||||
|  | 		margin: 0 20rpx; | ||||||
|  | 		>.title { | ||||||
|  | 			font-size: $font-base; | ||||||
|  | 			color: $font-color-dark; | ||||||
|  | 			line-height: 1.5; | ||||||
|  | 			height: 84rpx; | ||||||
|  | 			padding: 10rpx 0 0; | ||||||
|  | 			display: -webkit-box; | ||||||
|  | 			-webkit-box-orient: vertical; | ||||||
|  | 			-webkit-line-clamp: 2; | ||||||
|  | 			overflow: hidden; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		.promotion { | ||||||
|  | 			margin-top: 4rpx; | ||||||
|  | 			display: flex; | ||||||
|  | 
 | ||||||
|  | 			div { | ||||||
|  | 				span { | ||||||
|  | 					font-size: 24rpx; | ||||||
|  | 					color: $light-color; | ||||||
|  | 					margin-right: 10rpx; | ||||||
|  | 					padding: 0 4rpx; | ||||||
|  | 					border-radius: 2rpx; | ||||||
|  | 				} | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		.count-config { | ||||||
|  | 			padding: 5rpx 0; | ||||||
|  | 			color: #666; | ||||||
|  | 			display: flex; | ||||||
|  | 			font-size: 24rpx; | ||||||
|  | 			letter-spacing:2rpx; | ||||||
|  | 			padding-left: 10rpx; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.price-box { | ||||||
|  | 		margin-top: 10rpx; | ||||||
|  | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: space-between; | ||||||
|  | 		padding-right: 10rpx; | ||||||
|  | 		font-size: 24rpx; | ||||||
|  | 		color: $font-color-light; | ||||||
|  | 
 | ||||||
|  | 		>.price { | ||||||
|  | 			font-size: 26rpx; | ||||||
|  | 			line-height: 1; | ||||||
|  | 			color: $main-color; | ||||||
|  | 			font-weight: bold; | ||||||
|  | 
 | ||||||
|  | 			/deep/ span:nth-of-type(1) { | ||||||
|  | 				font-size: 48rpx; | ||||||
|  | 			} | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | </style> | ||||||
|  | @ -1,190 +0,0 @@ | ||||||
| <template> |  | ||||||
| 	<div> |  | ||||||
| 		<div v-for="(item, index) in res" :key="index" class="goods-row"> |  | ||||||
| 			<div class="flex goods-col"> |  | ||||||
| 				<div class="goods-img" @click="navigateToDetailPage(item)"> |  | ||||||
| 					<u-image width="230rpx" border-radius='16' height="230rpx" :src="item.goodsImage"> |  | ||||||
| 						<u-loading slot="loading"></u-loading> |  | ||||||
| 					</u-image> |  | ||||||
| 				</div> |  | ||||||
| 				<div class="goods-detail"> |  | ||||||
| 					<div class="title clamp3" @click="navigateToDetailPage(item)">{{ item.goodsName }}</div> |  | ||||||
| 					<view class="price-box" @click="navigateToDetailPage(item)"> |  | ||||||
| 						<div class="price" v-if="item.price!=undefined"> |  | ||||||
| 							¥<span>{{ formatPrice(item.price )[0] }} </span>.{{ |  | ||||||
| 			            formatPrice(item.price )[1] |  | ||||||
| 			          }} |  | ||||||
| 						</div> |  | ||||||
| 					</view> |  | ||||||
| 					<div class="promotion" @click="navigateToDetailPage(item)"> |  | ||||||
| 						<div v-if="item.salesModel == 'WHOLESALE'"> |  | ||||||
| 							<span>批</span> |  | ||||||
| 						</div> |  | ||||||
| 						<div v-for="(promotionItem,promotionIndex) in  getPromotion(item)" :key="promotionIndex"> |  | ||||||
| 							<span v-if="promotionItem.indexOf('COUPON') != -1">劵</span> |  | ||||||
| 							<span v-if="promotionItem.indexOf('FULL_DISCOUNT') != -1">满减</span> |  | ||||||
| 							<span v-if="promotionItem.indexOf('SECKILL') != -1">秒杀</span> |  | ||||||
| 						</div> |  | ||||||
| 					</div> |  | ||||||
| 					<div style="overflow: hidden" @click="navigateToDetailPage(item)" class="count-config"> |  | ||||||
| 						<span style="float: left; font-size: 22rpx">已售 {{ item.buyCount || '0' }}</span> |  | ||||||
| 						<span style="float: right; font-size: 22rpx">{{ item.commentNum || '0' }}条评论</span> |  | ||||||
| 					</div> |  | ||||||
| 					 |  | ||||||
| 				</div> |  | ||||||
| 			</div> |  | ||||||
| 
 |  | ||||||
| 		</div> |  | ||||||
| 	</div> |  | ||||||
| </template> |  | ||||||
| 
 |  | ||||||
| <script> |  | ||||||
| 	import commonTpl from '@/components/m-goods-list/common' |  | ||||||
| 	export default { |  | ||||||
| 		data() { |  | ||||||
| 			return { |  | ||||||
| 				lightColor: this.$mainColor |  | ||||||
| 			} |  | ||||||
| 		}, |  | ||||||
| 		mixins: [commonTpl], |  | ||||||
| 		props: { |  | ||||||
| 			// 遍历的数据 |  | ||||||
| 			res: { |  | ||||||
| 				type: Array, |  | ||||||
| 				default: () => { |  | ||||||
| 					return [] |  | ||||||
| 				} |  | ||||||
| 			}, |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| </script> |  | ||||||
| 
 |  | ||||||
| <style lang='scss' scoped> |  | ||||||
| .goods-list { |  | ||||||
| 			display: flex; |  | ||||||
| 			flex-wrap: wrap; |  | ||||||
| 			margin: 10rpx 20rpx 284rpx; |  | ||||||
| 			width: 100%; |  | ||||||
| 	 |  | ||||||
| 			>.goods-item { |  | ||||||
| 				background-color: #ffffff; |  | ||||||
| 				display: flex; |  | ||||||
| 				border-radius: 16rpx; |  | ||||||
| 				flex-direction: column; |  | ||||||
| 				width: calc(50% - 30rpx); |  | ||||||
| 				margin-bottom: 20rpx; |  | ||||||
| 				padding-bottom: 20rpx; |  | ||||||
| 	 |  | ||||||
| 				&:nth-child(2n + 1) { |  | ||||||
| 					margin-right: 20rpx; |  | ||||||
| 				} |  | ||||||
| 	 |  | ||||||
| 	 |  | ||||||
| 				.image-wrapper { |  | ||||||
| 					width: 100%; |  | ||||||
| 					height: 330rpx; |  | ||||||
| 					border-radius: 16rpx 16rpx 0 0; |  | ||||||
| 					overflow: hidden; |  | ||||||
| 					padding: 0; |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 			.count-config, |  | ||||||
| 			.store-seller-name { |  | ||||||
| 				font-size: $font-sm; |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 			.text-hidden { |  | ||||||
| 				overflow: hidden; |  | ||||||
| 				text-overflow: ellipsis; |  | ||||||
| 				white-space: nowrap; |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	 |  | ||||||
| 	 |  | ||||||
| 		.goods-row { |  | ||||||
| 			background: #fff; |  | ||||||
| 			padding: 16rpx; |  | ||||||
| 	 |  | ||||||
| 			>.goods-col { |  | ||||||
| 				display: flex; |  | ||||||
| 	 |  | ||||||
| 				>.goods-img { |  | ||||||
| 					overflow: hidden; |  | ||||||
| 					flex: 4; |  | ||||||
| 				} |  | ||||||
| 	 |  | ||||||
| 				>.goods-detail { |  | ||||||
| 					flex: 7; |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 		} |  | ||||||
| 	 |  | ||||||
| 		.goods-detail { |  | ||||||
| 			margin: 0 20rpx; |  | ||||||
| 	 |  | ||||||
| 			>.title { |  | ||||||
| 				font-size: $font-base; |  | ||||||
| 				color: $font-color-dark; |  | ||||||
| 				line-height: 1.5; |  | ||||||
| 				height: 84rpx; |  | ||||||
| 				padding: 10rpx 0 0; |  | ||||||
| 				display: -webkit-box; |  | ||||||
| 				-webkit-box-orient: vertical; |  | ||||||
| 				-webkit-line-clamp: 2; |  | ||||||
| 				overflow: hidden; |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 			.promotion { |  | ||||||
| 				margin-top: 4rpx; |  | ||||||
| 				display: flex; |  | ||||||
| 	 |  | ||||||
| 				div { |  | ||||||
| 					span { |  | ||||||
| 						font-size: 24rpx; |  | ||||||
| 						color: $light-color; |  | ||||||
| 						margin-right: 10rpx; |  | ||||||
| 						padding: 0 4rpx; |  | ||||||
| 						border-radius: 2rpx; |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 			.store-seller-name { |  | ||||||
| 				color: #666; |  | ||||||
| 				overflow: hidden; |  | ||||||
| 				display: flex; |  | ||||||
| 				justify-content: space-between; |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 			.count-config { |  | ||||||
| 				padding: 5rpx 0; |  | ||||||
| 				color: #666; |  | ||||||
| 				display: flex; |  | ||||||
| 				font-size: 24rpx; |  | ||||||
| 				justify-content: space-between; |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 			>.price-box { |  | ||||||
| 				margin-top: 10rpx; |  | ||||||
| 				display: flex; |  | ||||||
| 				align-items: center; |  | ||||||
| 				justify-content: space-between; |  | ||||||
| 				padding-right: 10rpx; |  | ||||||
| 				font-size: 24rpx; |  | ||||||
| 				color: $font-color-light; |  | ||||||
| 	 |  | ||||||
| 				>.price { |  | ||||||
| 					font-size: 26rpx; |  | ||||||
| 					line-height: 1; |  | ||||||
| 					color: $main-color; |  | ||||||
| 					font-weight: bold; |  | ||||||
| 	 |  | ||||||
| 					/deep/ span:nth-of-type(1) { |  | ||||||
| 						font-size: 38rpx; |  | ||||||
| 					} |  | ||||||
| 				} |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 		} |  | ||||||
| </style> |  | ||||||
|  | @ -62,7 +62,7 @@ export default { | ||||||
|       this.goodsList.push(...goodsList.data.result.content); |       this.goodsList.push(...goodsList.data.result.content); | ||||||
|     }, |     }, | ||||||
|     handleClick(item) { |     handleClick(item) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${item.content.id}&goodsId=${item.content.goodsId}`, |         url: `/pages/product/goods?id=${item.content.id}&goodsId=${item.content.goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -4,14 +4,8 @@ | ||||||
|  */ |  */ | ||||||
| // 开发环境
 | // 开发环境
 | ||||||
| const dev = { | const dev = { | ||||||
|   // common: "https://common-api.pickmall.cn",
 |   common: "https://common-api.pickmall.cn", | ||||||
|   // buyer: "https://buyer-api.pickmall.cn",
 |   buyer: "https://buyer-api.pickmall.cn", | ||||||
| 
 |  | ||||||
|   common: "http://192.168.0.106:8890", |  | ||||||
| 	  buyer: "http://192.168.0.106:8888", |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| }; | }; | ||||||
| // 生产环境
 | // 生产环境
 | ||||||
| const prod = { | const prod = { | ||||||
|  |  | ||||||
							
								
								
									
										4
									
								
								main.js
								
								
								
								
							
							
						
						
									
										4
									
								
								main.js
								
								
								
								
							|  | @ -3,7 +3,7 @@ import App from "./App"; | ||||||
| import * as filters from "./utils/filters.js"; // global filter
 | import * as filters from "./utils/filters.js"; // global filter
 | ||||||
| import uView from "uview-ui"; | import uView from "uview-ui"; | ||||||
| import store from "./store"; | import store from "./store"; | ||||||
| import {navigateTo} from '@/utils/navigateRoute.js' | 
 | ||||||
| 
 | 
 | ||||||
| /** | /** | ||||||
|  * 仅在h5中显示唤醒app功能 |  * 仅在h5中显示唤醒app功能 | ||||||
|  | @ -32,8 +32,6 @@ Object.keys(filters).forEach((key) => { | ||||||
| Vue.prototype.$store = store; | Vue.prototype.$store = store; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| // // 引入Vuex
 |  | ||||||
| Vue.prototype.$navigateTo = navigateTo; |  | ||||||
| Vue.use(uView); | Vue.use(uView); | ||||||
| Vue.config.productionTip = false; | Vue.config.productionTip = false; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -465,7 +465,9 @@ | ||||||
| 			"pages": [ { | 			"pages": [ { | ||||||
| 					"path": "seckill", | 					"path": "seckill", | ||||||
| 					"style": { | 					"style": { | ||||||
| 						"navigationBarTitleText": "限时抢购", | 						"navigationBarTitleText": "限时抢购", | ||||||
|  | 						"navigationStyle": "custom", // 隐藏系统导航栏 | ||||||
|  | 						"navigationBarTextStyle": "white" , | ||||||
| 						"app-plus": { | 						"app-plus": { | ||||||
| 							"titleNView": { | 							"titleNView": { | ||||||
| 								"homeButton":true | 								"homeButton":true | ||||||
|  | @ -478,7 +480,8 @@ | ||||||
| 					"path": "joinGroup", | 					"path": "joinGroup", | ||||||
| 					"style": { | 					"style": { | ||||||
| 						"navigationBarTitleText": "拼团活动", | 						"navigationBarTitleText": "拼团活动", | ||||||
| 						"navigationStyle": "custom", // 隐藏系统导航栏 | 						"navigationStyle": "custom", // 隐藏系统导航栏 | ||||||
|  | 						"navigationBarTextStyle": "white" , | ||||||
| 						"app-plus": { | 						"app-plus": { | ||||||
| 							// 将回弹属性关掉 | 							// 将回弹属性关掉 | ||||||
| 							"bounce": "none" | 							"bounce": "none" | ||||||
|  |  | ||||||
|  | @ -145,7 +145,7 @@ | ||||||
| 			}, | 			}, | ||||||
| 		}, | 		}, | ||||||
| 		onNavigationBarButtonTap(e) { | 		onNavigationBarButtonTap(e) { | ||||||
| 			this.$navigateTo({ | 			uni.navigateTo({ | ||||||
| 				url: "/pages/cart/coupon/couponIntro", | 				url: "/pages/cart/coupon/couponIntro", | ||||||
| 			}); | 			}); | ||||||
| 		}, | 		}, | ||||||
|  |  | ||||||
|  | @ -189,7 +189,7 @@ export default { | ||||||
|      */ |      */ | ||||||
|     useItNow(item) { |     useItNow(item) { | ||||||
|       if (item.storeId && item.storeId!='0') { |       if (item.storeId && item.storeId!='0') { | ||||||
|         this.$navigateTo({ |         uni.navigateTo({ | ||||||
|           url: `/pages/product/shopPage?id=${item.storeId}`, |           url: `/pages/product/shopPage?id=${item.storeId}`, | ||||||
|         }); |         }); | ||||||
|       } else { |       } else { | ||||||
|  | @ -203,7 +203,7 @@ export default { | ||||||
|      * 优惠券详情 |      * 优惠券详情 | ||||||
|      */ |      */ | ||||||
|     couponDetail(item) { |     couponDetail(item) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/cart/coupon/couponDetail?item=" + |           "/pages/cart/coupon/couponDetail?item=" + | ||||||
|           encodeURIComponent(JSON.stringify(item)), |           encodeURIComponent(JSON.stringify(item)), | ||||||
|  |  | ||||||
|  | @ -120,7 +120,7 @@ | ||||||
| 			 * 支付成功后跳转 | 			 * 支付成功后跳转 | ||||||
| 			 */ | 			 */ | ||||||
| 			callback(paymentMethod){ | 			callback(paymentMethod){ | ||||||
| 				this.$navigateTo({ | 				uni.navigateTo({ | ||||||
| 					url: "/pages/cart/payment/success?paymentMethod=" + | 					url: "/pages/cart/payment/success?paymentMethod=" + | ||||||
| 					paymentMethod + | 					paymentMethod + | ||||||
| 					"&payPrice=" + | 					"&payPrice=" + | ||||||
|  |  | ||||||
|  | @ -162,7 +162,7 @@ export default { | ||||||
|             delete this.form.updateTime; |             delete this.form.updateTime; | ||||||
|             editAddress(this.form).then((res) => { |             editAddress(this.form).then((res) => { | ||||||
|               if (res.data.success) { |               if (res.data.success) { | ||||||
|                 this.$navigateTo({ |                 uni.navigateTo({ | ||||||
|                   url: `/${beforePage.route}`, |                   url: `/${beforePage.route}`, | ||||||
|                 }); |                 }); | ||||||
|               } |               } | ||||||
|  |  | ||||||
|  | @ -129,7 +129,7 @@ export default { | ||||||
|     //新建。编辑地址 |     //新建。编辑地址 | ||||||
|     addAddress(id) { |     addAddress(id) { | ||||||
|       if (id) { |       if (id) { | ||||||
|         this.$navigateTo({ |         uni.navigateTo({ | ||||||
|           url: |           url: | ||||||
|             "/pages/mine/address/add?id=" + |             "/pages/mine/address/add?id=" + | ||||||
|             id + |             id + | ||||||
|  | @ -138,7 +138,7 @@ export default { | ||||||
|             "&type=order", |             "&type=order", | ||||||
|         }); |         }); | ||||||
|       } else { |       } else { | ||||||
|         this.$navigateTo({ |         uni.navigateTo({ | ||||||
|           url: |           url: | ||||||
|             "/pages/mine/address/add?way=" + this.routerVal.way + "&type=order", |             "/pages/mine/address/add?way=" + this.routerVal.way + "&type=order", | ||||||
|         }); |         }); | ||||||
|  |  | ||||||
|  | @ -86,23 +86,9 @@ export default { | ||||||
|    * 进入页面检测当前账户是否登录 |    * 进入页面检测当前账户是否登录 | ||||||
|    */ |    */ | ||||||
|   onShow() { |   onShow() { | ||||||
|     let that = this; |     if (this.$options.filters.tipsToLogin()) { | ||||||
|     if (this.$options.filters.isLogin("auth")) { |  | ||||||
|       this.getAddressList(); |       this.getAddressList(); | ||||||
|     } else { |     }  | ||||||
|       uni.showModal({ |  | ||||||
|         title: "提示", |  | ||||||
|         content: "检测到您的账号还未登录,是否去登录?", |  | ||||||
|         confirmColor: this.$lightColor, |  | ||||||
|         success: function (res) { |  | ||||||
|           if (res.confirm) { |  | ||||||
|             that.$options.filters.navigateToLogin(); |  | ||||||
|           } else if (res.cancel) { |  | ||||||
|             uni.navigateBack(); |  | ||||||
|           } |  | ||||||
|         }, |  | ||||||
|       }); |  | ||||||
|     } |  | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     //获取地址列表 |     //获取地址列表 | ||||||
|  | @ -145,7 +131,7 @@ export default { | ||||||
|     }, |     }, | ||||||
|     //新建。编辑地址 |     //新建。编辑地址 | ||||||
|     addAddress(id) { |     addAddress(id) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/mine/address/add${id ? "?id=" + id : ""}`, |         url: `/pages/mine/address/add${id ? "?id=" + id : ""}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -50,7 +50,7 @@ export default { | ||||||
|      * 跳转 |      * 跳转 | ||||||
|      */ |      */ | ||||||
|     navgition(url) { |     navgition(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -38,7 +38,7 @@ export default { | ||||||
|         |         | ||||||
|         let res = await recharge({ price: this.price }); |         let res = await recharge({ price: this.price }); | ||||||
|         if (res.data.success) { |         if (res.data.success) { | ||||||
|           this.$navigateTo({ |           uni.navigateTo({ | ||||||
|             url: `/pages/cart/payment/payOrder?orderType=RECHARGE&recharge_sn=${res.data.result.rechargeSn}`, |             url: `/pages/cart/payment/payOrder?orderType=RECHARGE&recharge_sn=${res.data.result.rechargeSn}`, | ||||||
|           }); |           }); | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  | @ -58,12 +58,12 @@ export default { | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     handleClick(url) { |     handleClick(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|     queryGoods(src) { |     queryGoods(src) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/mine/distribution/${src}`, |         url: `/pages/mine/distribution/${src}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -221,7 +221,7 @@ export default { | ||||||
|      * 查看图片 |      * 查看图片 | ||||||
|      */ |      */ | ||||||
|     handleNavgationGoods(val) { |     handleNavgationGoods(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${val.skuId}&goodsId=${val.goodsId}`, |         url: `/pages/product/goods?id=${val.skuId}&goodsId=${val.goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -56,7 +56,7 @@ | ||||||
| 		methods: { | 		methods: { | ||||||
| 			...mapMutations(["logout"]), | 			...mapMutations(["logout"]), | ||||||
| 			navigateTo(url) { | 			navigateTo(url) { | ||||||
| 				this.$navigateTo({ | 				uni.navigateTo({ | ||||||
| 					url | 					url | ||||||
| 				}); | 				}); | ||||||
| 			}, | 			}, | ||||||
|  |  | ||||||
|  | @ -45,7 +45,7 @@ export default { | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     goDetail(sn,logi_id,ship_no){ |     goDetail(sn,logi_id,ship_no){ | ||||||
| 		this.$navigateTo({ | 		uni.navigateTo({ | ||||||
| 			url:'/pages/msgTips/packagemsg/logisticsDetail?order_sn=' + sn +'&logi_id='+logi_id+'&ship_no='+ship_no, | 			url:'/pages/msgTips/packagemsg/logisticsDetail?order_sn=' + sn +'&logi_id='+logi_id+'&ship_no='+ship_no, | ||||||
| 		}) | 		}) | ||||||
| 	}, | 	}, | ||||||
|  |  | ||||||
|  | @ -174,7 +174,7 @@ | ||||||
| 			 */ | 			 */ | ||||||
| 			goGoodsDetail(val) { | 			goGoodsDetail(val) { | ||||||
| 				//商品详情 | 				//商品详情 | ||||||
| 				this.$navigateTo({ | 				uni.navigateTo({ | ||||||
| 					url: "/pages/product/goods?id=" + val.skuId + "&goodsId=" + val.goodsId, | 					url: "/pages/product/goods?id=" + val.skuId + "&goodsId=" + val.goodsId, | ||||||
| 				}); | 				}); | ||||||
| 			}, | 			}, | ||||||
|  | @ -184,7 +184,7 @@ | ||||||
| 			 */ | 			 */ | ||||||
| 			goStoreMainPage(id) { | 			goStoreMainPage(id) { | ||||||
| 				//店铺主页 | 				//店铺主页 | ||||||
| 				this.$navigateTo({ | 				uni.navigateTo({ | ||||||
| 					url: "/pages/product/shopPage?id=" + id, | 					url: "/pages/product/shopPage?id=" + id, | ||||||
| 				}); | 				}); | ||||||
| 			}, | 			}, | ||||||
|  |  | ||||||
|  | @ -84,7 +84,7 @@ | ||||||
| 			 * 导航到店铺 | 			 * 导航到店铺 | ||||||
| 			 */ | 			 */ | ||||||
| 			navgaiteToStore(val) { | 			navgaiteToStore(val) { | ||||||
| 				this.$navigateTo({ | 				uni.navigateTo({ | ||||||
| 					url: "/pages/product/shopPage?id=" + val.storeId, | 					url: "/pages/product/shopPage?id=" + val.storeId, | ||||||
| 				}); | 				}); | ||||||
| 			}, | 			}, | ||||||
|  | @ -100,7 +100,7 @@ | ||||||
| 			 * 跳转详情 | 			 * 跳转详情 | ||||||
| 			 */ | 			 */ | ||||||
| 			navgaiteToDetail(item) { | 			navgaiteToDetail(item) { | ||||||
| 				this.$navigateTo({ | 				uni.navigateTo({ | ||||||
| 					url: "/pages/product/goods?id=" + item.id + "&goodsId=" + item.goodsId, | 					url: "/pages/product/goods?id=" + item.id + "&goodsId=" + item.goodsId, | ||||||
| 				}); | 				}); | ||||||
| 			}, | 			}, | ||||||
|  |  | ||||||
|  | @ -88,7 +88,7 @@ export default { | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     navigateTo(url) { |     navigateTo(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -16,7 +16,7 @@ export default { | ||||||
| 
 | 
 | ||||||
|   methods: { |   methods: { | ||||||
|     navigateTo(url) { |     navigateTo(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: url, |         url: url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -49,7 +49,7 @@ export default { | ||||||
|       if (url == "/pages/set/securityCenter/securityCenter") { |       if (url == "/pages/set/securityCenter/securityCenter") { | ||||||
|         url += `?mobile=${this.userInfo.mobile}`; |         url += `?mobile=${this.userInfo.mobile}`; | ||||||
|       } |       } | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: url, |         url: url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -488,13 +488,13 @@ export default { | ||||||
|     }, |     }, | ||||||
|     // 跳转到商品详情 |     // 跳转到商品详情 | ||||||
|     navigateToDetailPage(item) { |     navigateToDetailPage(item) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${item.content.id}&goodsId=${item.content.goodsId}`, |         url: `/pages/product/goods?id=${item.content.id}&goodsId=${item.content.goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|     // 跳转地址 |     // 跳转地址 | ||||||
|     navigateToStoreDetailPage(item) { |     navigateToStoreDetailPage(item) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/shopPage?id=${item.content.storeId}`, |         url: `/pages/product/shopPage?id=${item.content.storeId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -352,7 +352,7 @@ export default { | ||||||
|      * 售后详情 |      * 售后详情 | ||||||
|      */ |      */ | ||||||
|     afterDetails(order) { |     afterDetails(order) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "./applyDetail?sn=" + order.sn, |         url: "./applyDetail?sn=" + order.sn, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -395,7 +395,7 @@ export default { | ||||||
|         ...sku, |         ...sku, | ||||||
|       }; |       }; | ||||||
|       storage.setAfterSaleData(data); |       storage.setAfterSaleData(data); | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/order/afterSales/afterSalesSelect?sn=${sn}`, |         url: `/pages/order/afterSales/afterSalesSelect?sn=${sn}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -411,7 +411,7 @@ export default { | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       storage.setAfterSaleData(data); |       storage.setAfterSaleData(data); | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `./afterSalesDetailExpress?serviceSn=${order.sn}`, |         url: `./afterSalesDetailExpress?serviceSn=${order.sn}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -422,13 +422,13 @@ export default { | ||||||
|     onDetail(goods, sku) { |     onDetail(goods, sku) { | ||||||
|       // 售后申请 |       // 售后申请 | ||||||
|       if (this.current == 0) { |       if (this.current == 0) { | ||||||
|         this.$navigateTo({ |         uni.navigateTo({ | ||||||
|           url: `/pages/product/goods?id=${sku.skuId}&goodsId=${ |           url: `/pages/product/goods?id=${sku.skuId}&goodsId=${ | ||||||
|             sku.goodsId || sku.goodsId |             sku.goodsId || sku.goodsId | ||||||
|           }`, |           }`, | ||||||
|         }); |         }); | ||||||
|       } else { |       } else { | ||||||
|         this.$navigateTo({ |         uni.navigateTo({ | ||||||
|           url: `/pages/product/goods?id=${goods.skuId}&goodsId=${ |           url: `/pages/product/goods?id=${goods.skuId}&goodsId=${ | ||||||
|             goods.goodsId || goods.goodsId |             goods.goodsId || goods.goodsId | ||||||
|           }`, |           }`, | ||||||
|  |  | ||||||
|  | @ -94,7 +94,7 @@ export default { | ||||||
|      * 跳转到商品信息 |      * 跳转到商品信息 | ||||||
|      */ |      */ | ||||||
|     navigateToGoodsDetail(id) { |     navigateToGoodsDetail(id) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${id}&goodsId=${goodsId}`, |         url: `/pages/product/goods?id=${id}&goodsId=${goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -381,7 +381,7 @@ export default { | ||||||
|      * 访问商品详情 |      * 访问商品详情 | ||||||
|      */ |      */ | ||||||
|     navgiateToGoodsDetail(item) { |     navgiateToGoodsDetail(item) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${item.id}&goodsId=${item.goodsId}`, |         url: `/pages/product/goods?id=${item.id}&goodsId=${item.goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -390,7 +390,7 @@ export default { | ||||||
|      * 进度 |      * 进度 | ||||||
|      */ |      */ | ||||||
|     onProgress() { |     onProgress() { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `./applyProgress?sn=${ |         url: `./applyProgress?sn=${ | ||||||
|           this.serviceDetail.sn |           this.serviceDetail.sn | ||||||
|         }&createTime=${encodeURIComponent(this.serviceDetail.createTime)} |         }&createTime=${encodeURIComponent(this.serviceDetail.createTime)} | ||||||
|  |  | ||||||
|  | @ -86,7 +86,7 @@ export default { | ||||||
|   methods: { |   methods: { | ||||||
|     // 点击跳转到商品 |     // 点击跳转到商品 | ||||||
|     handleToGoods(val) { |     handleToGoods(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/product/goods?id=" + val.skuId + "&goodsId=" + val.goodsId, |         url: "/pages/product/goods?id=" + val.skuId + "&goodsId=" + val.goodsId, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -120,7 +120,7 @@ export default { | ||||||
|      * 查看详情 |      * 查看详情 | ||||||
|      */ |      */ | ||||||
|     handleInfo(val) { |     handleInfo(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "./complainInfo?id=" + val.id, |         url: "./complainInfo?id=" + val.id, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -219,7 +219,7 @@ export default { | ||||||
|      */ |      */ | ||||||
|     talkCommont(sku) { |     talkCommont(sku) { | ||||||
|       console.log(sku); |       console.log(sku); | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `./releaseEvaluate?sn=${sku.sn}&sku=${encodeURIComponent( |         url: `./releaseEvaluate?sn=${sku.sn}&sku=${encodeURIComponent( | ||||||
|           JSON.stringify(sku) |           JSON.stringify(sku) | ||||||
|         )}`, |         )}`, | ||||||
|  | @ -270,7 +270,7 @@ export default { | ||||||
|      * 评价详情 |      * 评价详情 | ||||||
|      */ |      */ | ||||||
|     onDetail(comment) { |     onDetail(comment) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "./evaluateDetail?comment=" + |           "./evaluateDetail?comment=" + | ||||||
|           encodeURIComponent(JSON.stringify(comment)), |           encodeURIComponent(JSON.stringify(comment)), | ||||||
|  |  | ||||||
|  | @ -481,7 +481,7 @@ export default { | ||||||
| 
 | 
 | ||||||
|     // 跳转到店铺 |     // 跳转到店铺 | ||||||
|     navigateToStore(val) { |     navigateToStore(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/product/shopPage?id=" + val.storeId, |         url: "/pages/product/shopPage?id=" + val.storeId, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -555,7 +555,7 @@ export default { | ||||||
|      * 跳转 |      * 跳转 | ||||||
|      */ |      */ | ||||||
|     navigateTo(url) { |     navigateTo(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -326,10 +326,10 @@ export default { | ||||||
|     // this.loadData(this.status); |     // this.loadData(this.status); | ||||||
|   }, |   }, | ||||||
|   onShow() { |   onShow() { | ||||||
|     if (!this.tabCurrentIndex) { |     if(this.$options.filters.tipsToLogin()){ | ||||||
|      this.initData(0); |       if (!this.tabCurrentIndex) { | ||||||
|     } else { |         this.initData(0); | ||||||
|        |       } | ||||||
|     } |     } | ||||||
|     // this.loadData(this.status); |     // this.loadData(this.status); | ||||||
|   }, |   }, | ||||||
|  | @ -364,14 +364,14 @@ export default { | ||||||
|   methods: { |   methods: { | ||||||
|     // 售后 |     // 售后 | ||||||
|     applyService(order) { |     applyService(order) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/order/afterSales/afterSales?orderSn=${order.sn}`, |         url: `/pages/order/afterSales/afterSales?orderSn=${order.sn}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     // 店铺详情 |     // 店铺详情 | ||||||
|     navigateToStore(val) { |     navigateToStore(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/product/shopPage?id=" + val.storeId, |         url: "/pages/product/shopPage?id=" + val.storeId, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -423,7 +423,7 @@ export default { | ||||||
|         }).pay(); |         }).pay(); | ||||||
|         // #endif |         // #endif | ||||||
|         // #ifndef MP-WEIXIN |         // #ifndef MP-WEIXIN | ||||||
|         this.$navigateTo({ |         uni.navigateTo({ | ||||||
|           url: "/pages/cart/payment/payOrder?order_sn=" + val.sn, |           url: "/pages/cart/payment/payOrder?order_sn=" + val.sn, | ||||||
|         }); |         }); | ||||||
|         // #endif |         // #endif | ||||||
|  | @ -522,7 +522,7 @@ export default { | ||||||
|      * 跳转到订单详情 |      * 跳转到订单详情 | ||||||
|      */ |      */ | ||||||
|     navigateToOrderDetail(sn) { |     navigateToOrderDetail(sn) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "./orderDetail?sn=" + sn, |         url: "./orderDetail?sn=" + sn, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -588,7 +588,7 @@ export default { | ||||||
|      * 评价商品 |      * 评价商品 | ||||||
|      */ |      */ | ||||||
|     onComment(sn) { |     onComment(sn) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "./evaluate/myEvaluate", |         url: "./evaluate/myEvaluate", | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -599,7 +599,7 @@ export default { | ||||||
|     reBuy(order) { |     reBuy(order) { | ||||||
|       console.log(order); |       console.log(order); | ||||||
|       return; |       return; | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/product/goods?id=" + order.id + "&goodsId=" + order.goodsId, |           "/pages/product/goods?id=" + order.id + "&goodsId=" + order.goodsId, | ||||||
|       }); |       }); | ||||||
|  | @ -609,7 +609,7 @@ export default { | ||||||
|      * 查看物流 |      * 查看物流 | ||||||
|      */ |      */ | ||||||
|     navigateToLogistics(order) { |     navigateToLogistics(order) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/mine/msgTips/packageMsg/logisticsDetail?order_sn=" + order.sn, |           "/pages/mine/msgTips/packageMsg/logisticsDetail?order_sn=" + order.sn, | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|  | @ -277,7 +277,7 @@ export default { | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     tostore(val) { |     tostore(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/product/shopPage?id=" + val.storeId, |         url: "/pages/product/shopPage?id=" + val.storeId, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -294,7 +294,7 @@ export default { | ||||||
|     }, |     }, | ||||||
|     // #TODO 这块需要写一下 目前没有拼团的详细信息 |     // #TODO 这块需要写一下 目前没有拼团的详细信息 | ||||||
|     ByUserMessage(order) { |     ByUserMessage(order) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/cart/payment/shareOrderGoods?sn=" + |           "/pages/cart/payment/shareOrderGoods?sn=" + | ||||||
|           order.sn + |           order.sn + | ||||||
|  | @ -318,12 +318,12 @@ export default { | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|     onReceipt(val) { |     onReceipt(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/order/invoice/invoiceDetail?id=" + val.id, |         url: "/pages/order/invoice/invoiceDetail?id=" + val.id, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|     gotoGoodsDetail(sku) { |     gotoGoodsDetail(sku) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${sku.skuId}&goodsId=${sku.goodsId}`, |         url: `/pages/product/goods?id=${sku.skuId}&goodsId=${sku.goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -363,7 +363,7 @@ export default { | ||||||
|      * 投诉 |      * 投诉 | ||||||
|      */ |      */ | ||||||
|     complaint(sku) { |     complaint(sku) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/order/complain/complain?sn=" + |           "/pages/order/complain/complain?sn=" + | ||||||
|           this.sn + |           this.sn + | ||||||
|  | @ -373,7 +373,7 @@ export default { | ||||||
|     }, |     }, | ||||||
|     //售后按钮 |     //售后按钮 | ||||||
|     onAfterSales(sn, sku) { |     onAfterSales(sn, sku) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `./afterSales/afterSalesSelect?sn=${sn}&sku=${encodeURIComponent( |         url: `./afterSales/afterSalesSelect?sn=${sn}&sku=${encodeURIComponent( | ||||||
|           JSON.stringify(sku) |           JSON.stringify(sku) | ||||||
|         )}`, |         )}`, | ||||||
|  | @ -382,7 +382,7 @@ export default { | ||||||
|     // 去支付 |     // 去支付 | ||||||
|     toPay(val) { |     toPay(val) { | ||||||
|       val.sn |       val.sn | ||||||
|         ? this.$navigateTo({ |         ? uni.navigateTo({ | ||||||
|             url: "/pages/cart/payment/payOrder?order_sn=" + val.sn, |             url: "/pages/cart/payment/payOrder?order_sn=" + val.sn, | ||||||
|           }) |           }) | ||||||
|         : false; |         : false; | ||||||
|  | @ -459,12 +459,12 @@ export default { | ||||||
|     }, |     }, | ||||||
|     //评价商品 |     //评价商品 | ||||||
|     onComment(sn) { |     onComment(sn) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "./evaluate/myEvaluate", |         url: "./evaluate/myEvaluate", | ||||||
|       }); |       }); | ||||||
|     }, //查看物流 |     }, //查看物流 | ||||||
|     onLogistics(order) { |     onLogistics(order) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/mine/msgTips/packageMsg/logisticsDetail?logi_id=" + |           "/pages/mine/msgTips/packageMsg/logisticsDetail?logi_id=" + | ||||||
|           order.logi_id + |           order.logi_id + | ||||||
|  | @ -480,7 +480,7 @@ export default { | ||||||
|       this.reason = reason; |       this.reason = reason; | ||||||
|     }, |     }, | ||||||
|     reBuy(order) { |     reBuy(order) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/product/goods?id=" + order.id + "&goodsId=" + order.goodsId, |           "/pages/product/goods?id=" + order.id + "&goodsId=" + order.goodsId, | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|  | @ -545,7 +545,7 @@ export default { | ||||||
|              if (user.data.result.mobile) { |              if (user.data.result.mobile) { | ||||||
|                 whetherNavigate(); |                 whetherNavigate(); | ||||||
|               } else { |               } else { | ||||||
|                 this.$navigateTo({ |                 uni.navigateTo({ | ||||||
|                   url: "/pages/passport/bindUserPhone", |                   url: "/pages/passport/bindUserPhone", | ||||||
|                 }); |                 }); | ||||||
|               } |               } | ||||||
|  | @ -639,13 +639,13 @@ export default { | ||||||
|     }, |     }, | ||||||
|     // 跳转 |     // 跳转 | ||||||
|     navigateToPrivacy(val) { |     navigateToPrivacy(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/mine/help/tips?type=" + val, |         url: "/pages/mine/help/tips?type=" + val, | ||||||
|       }); |       }); | ||||||
|       console.log(val) |       console.log(val) | ||||||
|     }, |     }, | ||||||
|     navigateToPrivacys(val){ |     navigateToPrivacys(val){ | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url:"/pages/mine/help/tips?type="+ val, |         url:"/pages/mine/help/tips?type="+ val, | ||||||
|       }) |       }) | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -710,13 +710,13 @@ export default { | ||||||
|     linkMsgDetail() { |     linkMsgDetail() { | ||||||
|       // lili 基础客服 |       // lili 基础客服 | ||||||
| 	 | 	 | ||||||
| 	  this.$navigateTo({ | 	  uni.navigateTo({ | ||||||
| 		url: `/pages/tabbar/home/web-view?IM=${this.storeDetail.storeId}`, | 		url: `/pages/tabbar/home/web-view?IM=${this.storeDetail.storeId}`, | ||||||
| 	  }); | 	  }); | ||||||
| 		 | 		 | ||||||
| 		// udesk 代码   | 		// udesk 代码   | ||||||
| 		// if (this.storeDetail.merchantEuid) { | 		// if (this.storeDetail.merchantEuid) { | ||||||
| 		//   this.$navigateTo({ | 		//   uni.navigateTo({ | ||||||
| 		//     url: `/pages/tabbar/home/web-view?src=${this.IM}`, | 		//     url: `/pages/tabbar/home/web-view?src=${this.IM}`, | ||||||
| 		//   }); | 		//   }); | ||||||
| 		// } | 		// } | ||||||
|  | @ -736,7 +736,7 @@ export default { | ||||||
|         //   sign: this.storeDetail.yzfSign, |         //   sign: this.storeDetail.yzfSign, | ||||||
|         //   mpSign: this.storeDetail.yzfMpSign, |         //   mpSign: this.storeDetail.yzfMpSign, | ||||||
|         // }; |         // }; | ||||||
|         // this.$navigateTo({ |         // uni.navigateTo({ | ||||||
|         //   url: |         //   url: | ||||||
|         //     "/pages/product/customerservice/index?params=" + |         //     "/pages/product/customerservice/index?params=" + | ||||||
|         //     encodeURIComponent(JSON.stringify(params)), |         //     encodeURIComponent(JSON.stringify(params)), | ||||||
|  | @ -744,7 +744,7 @@ export default { | ||||||
|         // // #endif |         // // #endif | ||||||
|         // // #ifndef MP-WEIXIN |         // // #ifndef MP-WEIXIN | ||||||
|         // const sign = this.storeDetail.yzfSign; |         // const sign = this.storeDetail.yzfSign; | ||||||
|         // this.$navigateTo({ |         // uni.navigateTo({ | ||||||
|         //   url: |         //   url: | ||||||
|         //     "/pages/tabbar/home/web-view?src=https://yzf.qq.com/xv/web/static/chat/index.html?sign=" + |         //     "/pages/tabbar/home/web-view?src=https://yzf.qq.com/xv/web/static/chat/index.html?sign=" + | ||||||
|         //     sign, |         //     sign, | ||||||
|  | @ -908,7 +908,7 @@ export default { | ||||||
|      * 跳转到店铺页面 |      * 跳转到店铺页面 | ||||||
|      */ |      */ | ||||||
|     navigateToStore(store_id) { |     navigateToStore(store_id) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/shopPage?id=` + store_id, |         url: `/pages/product/shopPage?id=` + store_id, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -94,7 +94,7 @@ export default { | ||||||
|       ); |       ); | ||||||
|     }, |     }, | ||||||
|     toComment(id, grade) { |     toComment(id, grade) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/comment?id=${id}&grade=${grade}`, |         url: `/pages/product/comment?id=${id}&grade=${grade}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -54,7 +54,7 @@ export default { | ||||||
|       this.getShippingAddress() |       this.getShippingAddress() | ||||||
|     } |     } | ||||||
|     else{ |     else{ | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|          url: 'pages/passport/login' |          url: 'pages/passport/login' | ||||||
|       }); |       }); | ||||||
|     } |     } | ||||||
|  | @ -71,7 +71,7 @@ export default { | ||||||
| 
 | 
 | ||||||
|     getpicker() { |     getpicker() { | ||||||
|       // this.$refs.cityPicker.show(); |       // this.$refs.cityPicker.show(); | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/mine/address/add", |         url: "/pages/mine/address/add", | ||||||
|       }); |       }); | ||||||
|       this.closeAddress(); |       this.closeAddress(); | ||||||
|  |  | ||||||
|  | @ -57,13 +57,13 @@ export default { | ||||||
|     }, |     }, | ||||||
|     // 点击商品 |     // 点击商品 | ||||||
|     clickGoods(val) { |     clickGoods(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${val.content.id}&goodsId=${val.content.goodsId}`, |         url: `/pages/product/goods?id=${val.content.id}&goodsId=${val.content.goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     tostorePage(val) { |     tostorePage(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "../product/shopPage?id=" + val.storeId, |         url: "../product/shopPage?id=" + val.storeId, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -74,7 +74,7 @@ export default { | ||||||
|   }, |   }, | ||||||
|   methods: { |   methods: { | ||||||
|     handleClickStore(val){ |     handleClickStore(val){ | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|          url: `/pages/product/shopPage?id=${val.id}` |          url: `/pages/product/shopPage?id=${val.id}` | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -152,7 +152,7 @@ export default { | ||||||
| 
 | 
 | ||||||
|   methods: { |   methods: { | ||||||
|     getStoreLicencePhoto() { |     getStoreLicencePhoto() { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/licencePhoto?id=${this.storeId}`, |         url: `/pages/product/licencePhoto?id=${this.storeId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -190,7 +190,7 @@ export default { | ||||||
|       //   sign: this.storeInfo.yzfSign, |       //   sign: this.storeInfo.yzfSign, | ||||||
|       //   mpSign: this.storeInfo.yzfMpSign, |       //   mpSign: this.storeInfo.yzfMpSign, | ||||||
|       // }; |       // }; | ||||||
|       // this.$navigateTo({ |       // uni.navigateTo({ | ||||||
|       //   url: |       //   url: | ||||||
|       //     "/pages/product/customerservice/index?params=" + |       //     "/pages/product/customerservice/index?params=" + | ||||||
|       //     encodeURIComponent(JSON.stringify(params)), |       //     encodeURIComponent(JSON.stringify(params)), | ||||||
|  | @ -198,14 +198,14 @@ export default { | ||||||
|       // // #endif |       // // #endif | ||||||
|       // // #ifndef MP-WEIXIN |       // // #ifndef MP-WEIXIN | ||||||
|       // const sign = this.storeInfo.yzfSign; |       // const sign = this.storeInfo.yzfSign; | ||||||
|       // this.$navigateTo({ |       // uni.navigateTo({ | ||||||
|       //   url: |       //   url: | ||||||
|       //     "/pages/tabbar/home/web-view?src=https://yzf.qq.com/xv/web/static/chat/index.html?sign=" + |       //     "/pages/tabbar/home/web-view?src=https://yzf.qq.com/xv/web/static/chat/index.html?sign=" + | ||||||
|       //     sign, |       //     sign, | ||||||
|       // }); |       // }); | ||||||
|       // // #endif |       // // #endif | ||||||
| 			 | 			 | ||||||
| 			this.$navigateTo({ | 			uni.navigateTo({ | ||||||
| 			   url: `/pages/tabbar/home/web-view?IM=${this.storeId}`, | 			   url: `/pages/tabbar/home/web-view?IM=${this.storeId}`, | ||||||
| 			 }); | 			 }); | ||||||
|     }, |     }, | ||||||
|  | @ -227,7 +227,7 @@ export default { | ||||||
| 
 | 
 | ||||||
|     /**商品分类中商品集合 */ |     /**商品分类中商品集合 */ | ||||||
|     getCategoryGoodsList(val) { |     getCategoryGoodsList(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/shopPageGoods?title=${val.labelName}&id=${val.id}&storeId=${this.storeId}`, |         url: `/pages/product/shopPageGoods?title=${val.labelName}&id=${val.id}&storeId=${this.storeId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -237,7 +237,7 @@ export default { | ||||||
|      */ |      */ | ||||||
|     search() { |     search() { | ||||||
| 			console.log("点击") | 			console.log("点击") | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/navigation/search/searchPage?storeId=${this.storeId}&keyword=${this.keyword}`, |         url: `/pages/navigation/search/searchPage?storeId=${this.storeId}&keyword=${this.keyword}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ | ||||||
|     <u-navbar :custom-back="back" back-icon-color="#fff" :background="background" :border-bottom="false"> |     <u-navbar :custom-back="back" back-icon-color="#fff" :background="background" :border-bottom="false"> | ||||||
|     </u-navbar> |     </u-navbar> | ||||||
| 
 | 
 | ||||||
|     <div class="wrapper"> |     <div class="wrapper-box"> | ||||||
|       <!-- 砍价列表 --> |       <!-- 砍价列表 --> | ||||||
|       <div class="box box1"> |       <div class="box box1"> | ||||||
|         <div class="bargain"> |         <div class="bargain"> | ||||||
|  | @ -106,10 +106,6 @@ | ||||||
|       <popupGoods ref="popupGoods" :buyMask="maskFlag" @closeBuy="closePopupBuy" :goodsDetail="bargainDetail" |       <popupGoods ref="popupGoods" :buyMask="maskFlag" @closeBuy="closePopupBuy" :goodsDetail="bargainDetail" | ||||||
|         :goodsSpec="goodsSpec" v-if="bargainDetail.id " @handleClickSku="getGoodsDetail" /> |         :goodsSpec="goodsSpec" v-if="bargainDetail.id " @handleClickSku="getGoodsDetail" /> | ||||||
| 
 | 
 | ||||||
|       <!-- 产品详情 --> |  | ||||||
|       <div class=" box4"> |  | ||||||
| 
 |  | ||||||
|       </div> |  | ||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| </template> | </template> | ||||||
|  | @ -352,11 +348,11 @@ page { | ||||||
|   align-items: center; |   align-items: center; | ||||||
|   padding: 10rpx 0; |   padding: 10rpx 0; | ||||||
| } | } | ||||||
| .wrapper { | .wrapper-box { | ||||||
|   background: url("https://lilishop-oss.oss-cn-beijing.aliyuncs.com/aac88f4e8eff452a8010af42c4560b04.png"); |   background: url("https://lili-system.oss-cn-beijing.aliyuncs.com/kanjia.png"); | ||||||
|   background-repeat: no-repeat; |   background-repeat: no-repeat; | ||||||
|   background-size: 100% 100%; |   background-size: 100% 100%; | ||||||
|   height: 700rpx; |   height: 506rpx; | ||||||
|   width: 100%; |   width: 100%; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -371,16 +367,16 @@ page { | ||||||
|   } |   } | ||||||
| } | } | ||||||
| .box1 { | .box1 { | ||||||
|   top: 750rpx; |   top: 560rpx; | ||||||
| } | } | ||||||
| .box2 { | .box2 { | ||||||
|   top: 770rpx; |   top: 580rpx; | ||||||
| } | } | ||||||
| .box3 { | .box3 { | ||||||
|   top: 790rpx; |   top: 600rpx; | ||||||
| } | } | ||||||
| .box4 { | .box4 { | ||||||
|   top: 810rpx; |   top: 620  rpx; | ||||||
|   height: 200rpx; |   height: 200rpx; | ||||||
| } | } | ||||||
| .bargain-item { | .bargain-item { | ||||||
|  |  | ||||||
|  | @ -6,22 +6,7 @@ | ||||||
|       <!-- 砍价列表 --> |       <!-- 砍价列表 --> | ||||||
|       <div class="box"> |       <div class="box"> | ||||||
|         <!-- 已砍的商品 --> |         <!-- 已砍的商品 --> | ||||||
|         <div class="bargain" v-if="bargainList.length!=0"> |         <goodsTemplate type="kanJia" v-if="bargainList.length!=0" :res="bargainList" /> | ||||||
|           <div class="flex bargain-item" v-for="(item,index) in bargainList" :key="index"> |  | ||||||
|             <div class="goods-img"> |  | ||||||
|               <u-image width="150" height="150" :src="item.thumbnail"></u-image> |  | ||||||
|             </div> |  | ||||||
|             <div class="goods-config"> |  | ||||||
|               <div class="goods-title wes-2"> |  | ||||||
|                 {{item.goodsName}} |  | ||||||
|               </div> |  | ||||||
|               <div class="flex goods-buy"> |  | ||||||
|                 <div class="max-price">最低:<span>¥{{item.purchasePrice | unitPrice}}</span></div> |  | ||||||
|                 <div class="bargaining" @click="navigateToBargainDetail(item)">参与砍价</div> |  | ||||||
|               </div> |  | ||||||
|             </div> |  | ||||||
|           </div> |  | ||||||
|         </div> |  | ||||||
|         <div class="bargain empty" v-else> |         <div class="bargain empty" v-else> | ||||||
|           <u-empty text="暂无活动" mode="list"></u-empty> |           <u-empty text="暂无活动" mode="list"></u-empty> | ||||||
|         </div> |         </div> | ||||||
|  | @ -32,7 +17,9 @@ | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import { getBargainList } from "@/api/promotions"; | import { getBargainList } from "@/api/promotions"; | ||||||
|  | import goodsTemplate from '@/components/m-goods-list/promotion' | ||||||
| export default { | export default { | ||||||
|  |   components:{goodsTemplate}, | ||||||
|   data() { |   data() { | ||||||
|     return { |     return { | ||||||
|       background: { |       background: { | ||||||
|  | @ -74,7 +61,7 @@ export default { | ||||||
| 
 | 
 | ||||||
|     // 跳转到砍价详情 |     // 跳转到砍价详情 | ||||||
|     navigateToBargainDetail(val) { |     navigateToBargainDetail(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/promotion/bargain/detail?id=${val.id}`, |         url: `/pages/promotion/bargain/detail?id=${val.id}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -91,7 +78,7 @@ page { | ||||||
|   background: url("https://lili-system.oss-cn-beijing.aliyuncs.com/kanjia.png"); |   background: url("https://lili-system.oss-cn-beijing.aliyuncs.com/kanjia.png"); | ||||||
|   background-repeat: no-repeat; |   background-repeat: no-repeat; | ||||||
|   background-size: 100% 100%; |   background-size: 100% 100%; | ||||||
|   height: 600rpx; |   height: 506rpx; | ||||||
|   width: 100%; |   width: 100%; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | @ -99,7 +86,7 @@ page { | ||||||
|   background: #fff; |   background: #fff; | ||||||
|   border-radius: 20rpx; |   border-radius: 20rpx; | ||||||
|   position: relative; |   position: relative; | ||||||
|   top: 650rpx; |   top: 560rpx; | ||||||
|   width: 94%; |   width: 94%; | ||||||
|   margin: 0 auto; |   margin: 0 auto; | ||||||
|   > .bargain { |   > .bargain { | ||||||
|  |  | ||||||
|  | @ -67,7 +67,7 @@ export default { | ||||||
|     }, |     }, | ||||||
|     // 跳转到砍价详情 |     // 跳转到砍价详情 | ||||||
|     navigateToBargainDetail(val) { |     navigateToBargainDetail(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/promotion/bargain/detail?id=${val.kanjiaActivityGoodsId}`, |         url: `/pages/promotion/bargain/detail?id=${val.kanjiaActivityGoodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -1,155 +1,133 @@ | ||||||
| <template> | <template> | ||||||
|   <view class="wrapper"> | 	<view class="wrapper"> | ||||||
|  | 		<u-navbar :border-bottom="false"  :title="title"> | ||||||
|  | 			<!-- 中间 --> | ||||||
|  | 			<view class="slot-wrap container-wrap"> | ||||||
|  | 				<view v-if="search"> | ||||||
|  | 					<u-search @search="searchFun()" @custom="searchFun()" v-model="params.goodsName"></u-search> | ||||||
|  | 				</view> | ||||||
|  | 			</view> | ||||||
|  | 			<!-- 右侧 --> | ||||||
|  | 			<view slot="right"> | ||||||
|  | 				<view style="margin-right: 24rpx;" @click="searchFlag()"> | ||||||
|  | 					<view v-if="search">取消</view> | ||||||
|  | 					<u-icon v-if="!search" size="44rpx" name="search"></u-icon> | ||||||
|  | 				</view> | ||||||
|  | 			</view> | ||||||
|  | 		</u-navbar> | ||||||
|  | 		<!-- 顶部栏 --> | ||||||
|  | 		<div class='header-wraper'> | ||||||
|  | 			<image  src="/static/join-buy.png"></image> | ||||||
|  | 		</div> | ||||||
|  | 		<!-- 商品栏 --> | ||||||
|  | 		<div class="swiper"> | ||||||
|  | 			<goodsTemplate v-if="goodsList.length" :res="goodsList" /> | ||||||
|  | 			 | ||||||
|  | 			<u-empty v-else style="margin-top:20%" text="暂无拼团活动" mode="data"></u-empty> | ||||||
|  | 		</div> | ||||||
| 
 | 
 | ||||||
|     <u-navbar :border-bottom="false" :background="background" class="unavbar" :title="title"> | 	</view> | ||||||
|       <!-- 中间 --> |  | ||||||
|       <view class="slot-wrap container-wrap"> |  | ||||||
| 
 |  | ||||||
|         <view v-if="search"> |  | ||||||
|           <u-search @search="searchFun()" @custom="searchFun()" v-model="params.goodsName"></u-search> |  | ||||||
|         </view> |  | ||||||
| 
 |  | ||||||
|       </view> |  | ||||||
|       <!-- 右侧 --> |  | ||||||
|       <view slot="right"> |  | ||||||
|         <view style="margin-right: 24rpx;" @click="searchFlag()"> |  | ||||||
|           <view v-if="search">取消</view> |  | ||||||
|           <u-icon v-if="!search" size="44rpx" name="search"></u-icon> |  | ||||||
|         </view> |  | ||||||
|       </view> |  | ||||||
|     </u-navbar> |  | ||||||
|     <!-- 顶部栏 --> |  | ||||||
| 
 |  | ||||||
|     <!-- 商品栏 --> |  | ||||||
|     <div class="swiper"> |  | ||||||
| 
 |  | ||||||
|       <div v-if="groupBuy.length !=0"> |  | ||||||
|         <view class="view-item" v-for="(groupItem, groupIndex) in groupBuy" :key="groupIndex"> |  | ||||||
|           <view class="view-left"> |  | ||||||
|             <u-image border-radius="10" shape="square" :src="groupItem.thumbnail" width="186rpx" height="186rpx"> |  | ||||||
| 
 |  | ||||||
|               <view slot="error" style="font-size: 24rpx;">加载失败</view> |  | ||||||
|             </u-image> |  | ||||||
|           </view> |  | ||||||
|           <view class="view-content"> |  | ||||||
|             <view class="view-content-name"> |  | ||||||
|               {{ groupItem.goodsName }} |  | ||||||
|             </view> |  | ||||||
|             <view class="view-content-bottom"> |  | ||||||
|               <view> |  | ||||||
|                 <view class="view-content-price"> |  | ||||||
|                   <!-- ¥{{groupItem.sales_price | unitPrice }} <span v-if="groupItem.point">+{{groupItem.point}}积分</span> --> |  | ||||||
|                   ¥{{groupItem.price | unitPrice }} |  | ||||||
|                 </view> |  | ||||||
|                 <view class="view-content-original_price"> |  | ||||||
|                   ¥{{ groupItem.originalPrice | unitPrice }} |  | ||||||
|                 </view> |  | ||||||
|               </view> |  | ||||||
| 
 |  | ||||||
|               <view> |  | ||||||
|                 <view class="btn-group" @click="toHref(groupItem)"> 去拼团 </view> |  | ||||||
|                 <view class="buy-content">已售{{groupItem.num || 0}}件</view> |  | ||||||
|               </view> |  | ||||||
|             </view> |  | ||||||
|           </view> |  | ||||||
|         </view> |  | ||||||
|         <u-loadmore bg-color='#f8f8f8' :status="status" /> |  | ||||||
|       </div> |  | ||||||
|       <u-empty v-else style="margin-top:20%" text="暂无拼团活动" mode="data"></u-empty> |  | ||||||
| 
 |  | ||||||
|     </div> |  | ||||||
| 
 |  | ||||||
|   </view> |  | ||||||
| </template> | </template> | ||||||
| 
 | 
 | ||||||
| <script> | <script> | ||||||
| import * as API_Promotions from "@/api/promotions"; | 	import * as API_Promotions from "@/api/promotions"; | ||||||
| import * as API_Goods from "@/api/goods"; | 	import * as API_Goods from "@/api/goods"; | ||||||
| export default { | 	import goodsTemplate from '@/components/m-goods-list/promotion.vue' | ||||||
|   components: {}, | 	export default { | ||||||
|   data() { | 		components: { | ||||||
|     return { | 			goodsTemplate | ||||||
|       status: "loadmore", | 		}, | ||||||
|       is_empty: false, | 		data() { | ||||||
|       search: false, | 			return { | ||||||
|       title: "拼团活动", | 				is_empty: false, | ||||||
|       background: { | 				search: false, | ||||||
|         backgroundColor: "#fff", | 				title: "拼团活动", | ||||||
|       }, |  | ||||||
|       empty: false, |  | ||||||
|       params: { |  | ||||||
|         pageNumber: 1, |  | ||||||
|         pageSize: 10, |  | ||||||
|         categoryPath: "", |  | ||||||
|         goodsName: "", |  | ||||||
|       }, |  | ||||||
|       groupBuy: [], |  | ||||||
|     }; |  | ||||||
|   }, |  | ||||||
|   mounted() {}, |  | ||||||
|   watch: { |  | ||||||
|     search(val) { |  | ||||||
|       val ? (this.title = "") : (this.title = "拼团活动"); |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
|   onReachBottom() { |  | ||||||
|     this.loadMore(); |  | ||||||
|   }, |  | ||||||
|   // 点击搜索按钮 |  | ||||||
|   onNavigationBarButtonTap(e) { |  | ||||||
|     this.popupFlag = !this.popupFlag; |  | ||||||
|   }, |  | ||||||
|   async onLoad() { |  | ||||||
|     this.GET_AssembleGoods(); |  | ||||||
|   }, |  | ||||||
| 
 | 
 | ||||||
|   methods: { | 				empty: false, | ||||||
|     loadMore() { | 				params: { | ||||||
|       this.params.pageNumber++; | 					pageNumber: 1, | ||||||
|       this.GET_AssembleGoods(); | 					pageSize: 10, | ||||||
|     }, | 					categoryPath: "", | ||||||
|     searchFlag() { | 					goodsName: "", | ||||||
|       this.search = !this.search; | 				}, | ||||||
|     }, | 				goodsList: [], | ||||||
|  | 			}; | ||||||
|  | 		}, | ||||||
|  | 		mounted() {}, | ||||||
|  | 		watch: { | ||||||
|  | 			search(val) { | ||||||
|  | 				val ? (this.title = "") : (this.title = "拼团活动"); | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 		onReachBottom() { | ||||||
|  | 			this.loadMore(); | ||||||
|  | 		}, | ||||||
|  | 		// 点击搜索按钮 | ||||||
|  | 		onNavigationBarButtonTap(e) { | ||||||
|  | 			this.popupFlag = !this.popupFlag; | ||||||
|  | 		}, | ||||||
|  | 		async onLoad() { | ||||||
|  | 			this.GET_AssembleGoods(); | ||||||
|  | 		}, | ||||||
| 
 | 
 | ||||||
|     toHref(goods) { | 		methods: { | ||||||
|       this.$navigateTo({ | 			loadMore() { | ||||||
|         url: `/pages/product/goods?id=${goods.skuId}&goodsId=${goods.goodsId}`, | 				this.params.pageNumber++; | ||||||
|       }); | 				this.GET_AssembleGoods(); | ||||||
|     }, | 			}, | ||||||
|     searchFun() { | 			searchFlag() { | ||||||
|       this.groupBuy = []; | 				this.search = !this.search; | ||||||
|       this.GET_AssembleGoods(); | 			}, | ||||||
|     }, |  | ||||||
|     // 请求拼团数据 |  | ||||||
|     GET_AssembleGoods() { |  | ||||||
|       this.status = "loading"; |  | ||||||
|       const params = JSON.parse(JSON.stringify(this.params)); |  | ||||||
|       if (params.category_id === 0) delete params.category_id; |  | ||||||
| 
 | 
 | ||||||
|       API_Promotions.getAssembleList(params) | 			toHref(goods) { | ||||||
|         .then((response) => { | 				uni.navigateTo({ | ||||||
|           const data = response.data.result.records; | 					url: `/pages/product/goods?id=${goods.skuId}&goodsId=${goods.goodsId}`, | ||||||
|  | 				}); | ||||||
|  | 			}, | ||||||
|  | 			searchFun() { | ||||||
|  | 				this.goodsList = []; | ||||||
|  | 				this.GET_AssembleGoods(); | ||||||
|  | 			}, | ||||||
|  | 			// 请求拼团数据 | ||||||
|  | 			GET_AssembleGoods() { | ||||||
| 
 | 
 | ||||||
|           if (!data || !data.length) { | 				const params = JSON.parse(JSON.stringify(this.params)); | ||||||
|             this.is_empty = true; | 				if (params.category_id === 0) delete params.category_id; | ||||||
|             this.status = "nomore"; | 
 | ||||||
|           } else { | 				API_Promotions.getAssembleList(params) | ||||||
|             if (data.length <= this.params.pageSize) { | 					.then((response) => { | ||||||
|               this.status = "nomore"; | 						const data = response.data.result.records; | ||||||
|             } else { | 
 | ||||||
|               this.status = "loadmore"; | 						if (!data || !data.length) { | ||||||
|             } | 							this.is_empty = true; | ||||||
|             this.is_empty = false; | 
 | ||||||
|             this.groupBuy.push(...(data || [])); | 						} else { | ||||||
|           } | 							if (data.length <= this.params.pageSize) { | ||||||
|         }) | 
 | ||||||
|         .catch(() => {}); | 							} else { | ||||||
|     }, | 
 | ||||||
|   }, | 							} | ||||||
| }; | 							this.is_empty = false; | ||||||
|  | 							this.goodsList.push(...(data || [])); | ||||||
|  | 						} | ||||||
|  | 					}) | ||||||
|  | 					.catch(() => {}); | ||||||
|  | 			}, | ||||||
|  | 		}, | ||||||
|  | 	}; | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
| <style lang="scss" scoped> | <style lang="scss" scoped> | ||||||
| @import "./style.scss"; | 	.header-wraper { | ||||||
|  | 		background: url('/static/bg.png'); | ||||||
|  | 		height: 200rpx; | ||||||
|  | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		>image{ | ||||||
|  | 			width: 188rpx; | ||||||
|  | 			height: 60rpx; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
|  | @ -229,7 +229,7 @@ export default { | ||||||
|       let customParams = encodeURIComponent( |       let customParams = encodeURIComponent( | ||||||
|         JSON.stringify({ path: "pages/index/index", pid: 1 }) |         JSON.stringify({ path: "pages/index/index", pid: 1 }) | ||||||
|       ); // 开发者在直播间页面路径上携带自定义参数,后续可以在分享卡片链接和跳转至商详页时获取,详见【获取自定义参数】、【直播间到商详页面携带参数】章节(上限600个字符,超过部分会被截断) |       ); // 开发者在直播间页面路径上携带自定义参数,后续可以在分享卡片链接和跳转至商详页时获取,详见【获取自定义参数】、【直播间到商详页面携带参数】章节(上限600个字符,超过部分会被截断) | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "plugin-private://wx2b03c6e691cd7370/pages/live-player-plugin?room_id=" + |           "plugin-private://wx2b03c6e691cd7370/pages/live-player-plugin?room_id=" + | ||||||
|           roomId + |           roomId + | ||||||
|  |  | ||||||
|  | @ -23,8 +23,8 @@ | ||||||
|                   <u-loading slot="loading"></u-loading> |                   <u-loading slot="loading"></u-loading> | ||||||
|                 </u-image> |                 </u-image> | ||||||
|                 <view class="index-item-title">{{ item.goodsName }}</view> |                 <view class="index-item-title">{{ item.goodsName }}</view> | ||||||
|                 <view class="index-item-price"> |                 <view class="index-item-price flex flex-a-c flex-j-sb"> | ||||||
|                   {{ item.points }}积分 |                   <div class="point"><span>{{ item.points }}</span>积分</div>  | ||||||
|                   <span class="tipsMkt">¥{{ item.originalPrice | unitPrice }}</span> |                   <span class="tipsMkt">¥{{ item.originalPrice | unitPrice }}</span> | ||||||
|                 </view> |                 </view> | ||||||
|               </view> |               </view> | ||||||
|  | @ -137,14 +137,14 @@ export default { | ||||||
|   methods: { |   methods: { | ||||||
|     // 跳转 |     // 跳转 | ||||||
|     navigateTo(url) { |     navigateTo(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     toGoods(item) { |     toGoods(item) { | ||||||
|       //跳转详情 |       //跳转详情 | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/promotion/point/detail?id=${item.id}`, |         url: `/pages/promotion/point/detail?id=${item.id}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -194,46 +194,12 @@ page { | ||||||
|   height: 100%; |   height: 100%; | ||||||
| } | } | ||||||
| .tipsMkt { | .tipsMkt { | ||||||
|   float: right; |  | ||||||
|   color: #c0c4cc; |   color: #c0c4cc; | ||||||
|   font-size: 24rpx; |   font-size: 24rpx !important; | ||||||
|   text-decoration: line-through; |   text-decoration: line-through; | ||||||
|   margin-right: 20rpx; |   margin-right: 20rpx !important; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .header { |  | ||||||
|   background: $light-color; |  | ||||||
|   position: relative; |  | ||||||
|   color: #fff; |  | ||||||
|   display: flex; |  | ||||||
|   height: 80rpx; |  | ||||||
|   align-items: center; |  | ||||||
|   justify-content: center; |  | ||||||
|   font-size: 26rpx; |  | ||||||
|   font-size: 34rpx; |  | ||||||
| 
 |  | ||||||
|   .left, |  | ||||||
|   .right { |  | ||||||
|     position: absolute; |  | ||||||
|     width: max-content; |  | ||||||
|     height: max-content; |  | ||||||
|     top: 0; |  | ||||||
|     bottom: 0; |  | ||||||
|     margin: auto; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   .left { |  | ||||||
|     float: left; |  | ||||||
|     top: 0; |  | ||||||
|     bottom: 0; |  | ||||||
|     left: 20rpx; |  | ||||||
|   } |  | ||||||
| 
 |  | ||||||
|   .right { |  | ||||||
|     float: right; |  | ||||||
|     right: 20rpx; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| .index { | .index { | ||||||
|   height: 100vh; |   height: 100vh; | ||||||
|  | @ -341,15 +307,19 @@ page { | ||||||
|   overflow: hidden; |   overflow: hidden; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .index-item-title-desc { | 
 | ||||||
|   font-size: 25rpx; |  | ||||||
|   color: #999999; |  | ||||||
|   margin-top: 10rpx; |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| .index-item-price { | .index-item-price { | ||||||
|   font-size: 28rpx; |   font-size: 28rpx; | ||||||
|   color: #ff5a10; |   overflow: hidden; | ||||||
|  |   color: $main-color; | ||||||
|   padding: 20rpx 0 0 20rpx; |   padding: 20rpx 0 0 20rpx; | ||||||
|  |   >.point{ | ||||||
|  |     >span{ | ||||||
|  |       font-size: 42rpx; | ||||||
|  |       font-weight: bold; | ||||||
|  |       margin-right:10rpx; | ||||||
|  |     } | ||||||
|  |   } | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
|  | @ -1,7 +1,8 @@ | ||||||
| <template> | <template> | ||||||
| 	<view class="sale"> | 	<view class="sale"> | ||||||
| 		<view class="sale-head"> | 		<u-navbar title='限时抢购'></u-navbar> | ||||||
| 			<image src="@/pages/promotion/static/head-sample.png"></image> | 		<view class="header-wraper"> | ||||||
|  | 				<image mode="widthFix" src="/static/seckill.png"></image> | ||||||
| 		</view> | 		</view> | ||||||
| 		<scroll-view scroll-x> | 		<scroll-view scroll-x> | ||||||
| 			<view class="index-navs"> | 			<view class="index-navs"> | ||||||
|  | @ -14,10 +15,7 @@ | ||||||
| 					</view> | 					</view> | ||||||
| 				</view> | 				</view> | ||||||
| 			</view> | 			</view> | ||||||
| 			<view class="trailer" v-if="timeLine[nav] && times"> | 			 | ||||||
| 				{{ timeLine[nav].distanceStartTime === 0 ? (onlyOne ? '距结束' : '距下一轮') : '距开始' }} |  | ||||||
| 				{{ times.hours == '00' ? '0' : times.hours }}小时{{ times.minutes }}分{{ times.seconds }}秒 |  | ||||||
| 			</view> |  | ||||||
| 		</scroll-view> | 		</scroll-view> | ||||||
| 		<view class="sale-items" v-if="goodsList.length > 0"> | 		<view class="sale-items" v-if="goodsList.length > 0"> | ||||||
| 			<goodsTemplate :res="goodsList" /> | 			<goodsTemplate :res="goodsList" /> | ||||||
|  | @ -39,7 +37,7 @@ | ||||||
| 		getSeckillTimeGoods | 		getSeckillTimeGoods | ||||||
| 	} from "@/api/promotions.js"; | 	} from "@/api/promotions.js"; | ||||||
| 	import Foundation from "@/utils/Foundation.js"; | 	import Foundation from "@/utils/Foundation.js"; | ||||||
| 	import goodsTemplate from '@/components/m-goods-list/seckill.vue' | 	import goodsTemplate from '@/components/m-goods-list/promotion.vue' | ||||||
| 	export default { | 	export default { | ||||||
| 		components: { | 		components: { | ||||||
| 			goodsTemplate | 			goodsTemplate | ||||||
|  | @ -184,10 +182,15 @@ | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.sale-head { | 	.header-wraper { | ||||||
| 		image { | 		background: url('/static/bg.png'); | ||||||
| 			width: 100%; | 		height: 200rpx; | ||||||
| 			height: 280rpx; | 		display: flex; | ||||||
|  | 		align-items: center; | ||||||
|  | 		justify-content: center; | ||||||
|  | 		>image{ | ||||||
|  | 			width: 300rpx; | ||||||
|  | 			height: 100rpx; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | @ -195,22 +198,8 @@ | ||||||
| 		padding-top: 20rpx; | 		padding-top: 20rpx; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.trailer { | 	.index-navs { | ||||||
| 		height: 100rpx; | 		background: #fff; | ||||||
| 		background: #ffffff; |  | ||||||
| 		display: -webkit-box; |  | ||||||
| 		display: -webkit-flex; |  | ||||||
| 		display: flex; |  | ||||||
| 		justify-content: center; |  | ||||||
| 		align-items: center; |  | ||||||
| 		font-size: 22rpx; |  | ||||||
| 		color: #666666; |  | ||||||
| 		box-sizing: border-box; |  | ||||||
| 		position: relative; |  | ||||||
| 		z-index: 0; |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	.index-navs { |  | ||||||
| 		background-color: #f7f7f7; | 		background-color: #f7f7f7; | ||||||
| 		display: -webkit-box; | 		display: -webkit-box; | ||||||
| 		display: -webkit-flex; | 		display: -webkit-flex; | ||||||
|  | @ -240,24 +229,26 @@ | ||||||
| 		color: #bababa; | 		color: #bababa; | ||||||
| 		height: 115rpx; | 		height: 115rpx; | ||||||
| 		line-height: 1em; | 		line-height: 1em; | ||||||
| 		position: relative; | 		position: relative; | ||||||
|  | 		font-size: 32rpx; | ||||||
|  | 		font-weight: bold; | ||||||
| 
 | 
 | ||||||
| 		&-active { | 		&-active { | ||||||
| 			background-image: url(/static/seckill/active.png); | 			color: $main-color; | ||||||
| 			background-size: 100% 115rpx; |  | ||||||
| 			background-repeat: no-repeat; |  | ||||||
| 			color: #ffffff; |  | ||||||
| 			position: relative; | 			position: relative; | ||||||
| 			z-index: 30; | 			z-index: 30; | ||||||
| 
 |  | ||||||
| 			.index-nav-desc { | 			.index-nav-desc { | ||||||
| 				color: #ffffff; | 				color: #fff; | ||||||
|  | 				font-weight: bold; | ||||||
|  | 				background: $main-color; | ||||||
|  | 				padding: 6rpx 16rpx; | ||||||
|  | 				border-radius: 50px; | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	.index-nav-desc { | 	.index-nav-desc { | ||||||
| 		margin-top: 8rpx; | 		margin-top: 8rpx; | ||||||
| 		font-size: 22rpx; | 		font-size: 22rpx; | ||||||
| 		color: #bababa; | 		color: #bababa; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | @ -343,7 +343,7 @@ export default { | ||||||
|      * 跳转到店铺 |      * 跳转到店铺 | ||||||
|      */ |      */ | ||||||
|     navigateToStore(val) { |     navigateToStore(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/product/shopPage?id=" + val.storeId, |         url: "/pages/product/shopPage?id=" + val.storeId, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -352,7 +352,7 @@ export default { | ||||||
|      * 跳转到优惠券 |      * 跳转到优惠券 | ||||||
|      */ |      */ | ||||||
|     navigateToConpon(val) { |     navigateToConpon(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/cart/coupon/couponCenter?storeId=" + val.storeId, |         url: "/pages/cart/coupon/couponCenter?storeId=" + val.storeId, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -361,7 +361,7 @@ export default { | ||||||
|      * 跳转到商品 |      * 跳转到商品 | ||||||
|      */ |      */ | ||||||
|     navigateToGoods(val) { |     navigateToGoods(val) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/product/goods?id=" + |           "/pages/product/goods?id=" + | ||||||
|           val.goodsSku.id + |           val.goodsSku.id + | ||||||
|  | @ -437,7 +437,7 @@ export default { | ||||||
|      * 跳转 |      * 跳转 | ||||||
|      */ |      */ | ||||||
|     navigateTo(url) { |     navigateTo(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -57,7 +57,7 @@ export default { | ||||||
|      * 查询 |      * 查询 | ||||||
|      */ |      */ | ||||||
|     search() { |     search() { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/navigation/search/searchPage", |         url: "/pages/navigation/search/searchPage", | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -90,7 +90,7 @@ export default { | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     navigateToList(sid, tid) { |     navigateToList(sid, tid) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/navigation/search/searchPage?category=${tid}`, |         url: `/pages/navigation/search/searchPage?category=${tid}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -24,7 +24,9 @@ | ||||||
|             {{ item.title }} |             {{ item.title }} | ||||||
|           </div> |           </div> | ||||||
|           <div class="goods-bottom"> |           <div class="goods-bottom"> | ||||||
|             <div class="goods-price">¥{{ item.price | unitPrice }}</div> |             <div class="goods-price">	¥<span>{{ formatPrice(item.price )[0] }} </span>.{{ | ||||||
|  | 										formatPrice(item.price )[1] | ||||||
|  | 									}}</div> | ||||||
|           </div> |           </div> | ||||||
|         </div> |         </div> | ||||||
|       </div> |       </div> | ||||||
|  | @ -56,8 +58,15 @@ export default { | ||||||
|   }, |   }, | ||||||
|   mounted() {}, |   mounted() {}, | ||||||
|   methods: { |   methods: { | ||||||
|  |     	// 格式化金钱  1999 --> [1999,00] | ||||||
|  | 			formatPrice(val) { | ||||||
|  | 				if (typeof val == "undefined") { | ||||||
|  | 					return val; | ||||||
|  | 				} | ||||||
|  | 				return val.toFixed(2).split("."); | ||||||
|  | 			}, | ||||||
|     handleClick(item) { |     handleClick(item) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: `/pages/product/goods?id=${item.id}&goodsId=${item.goodsId}`, |         url: `/pages/product/goods?id=${item.id}&goodsId=${item.goodsId}`, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -163,13 +172,11 @@ $w_94: 94%; | ||||||
|     > .goods-price { |     > .goods-price { | ||||||
|       line-height: 2; |       line-height: 2; | ||||||
|       color: $main-color; |       color: $main-color; | ||||||
|  |       >span{ | ||||||
|  |         font-size: 42rpx; | ||||||
|  |       } | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .goods-icon { |  | ||||||
|   right: 10rpx; |  | ||||||
|   top: 10rpx; |  | ||||||
|   position: absolute; |  | ||||||
| } |  | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
|  | @ -147,22 +147,22 @@ export default { | ||||||
|     goToDetail(type) { |     goToDetail(type) { | ||||||
|       switch(type) { |       switch(type) { | ||||||
|         case "SECKILL": |         case "SECKILL": | ||||||
|           this.$navigateTo({ |           uni.navigateTo({ | ||||||
|             url: `/pages/promotion/seckill`, |             url: `/pages/promotion/seckill`, | ||||||
|           }); |           }); | ||||||
|           break; |           break; | ||||||
|         case "PINTUAN": |         case "PINTUAN": | ||||||
|           this.$navigateTo({ |           uni.navigateTo({ | ||||||
|             url: `/pages/promotion/joinGroup`, |             url: `/pages/promotion/joinGroup`, | ||||||
|           }); |           }); | ||||||
|           break; |           break; | ||||||
|         case "LIVE": |         case "LIVE": | ||||||
|           this.$navigateTo({ |           uni.navigateTo({ | ||||||
|             url: `/pages/promotion/lives`, |             url: `/pages/promotion/lives`, | ||||||
|           }); |           }); | ||||||
|           break; |           break; | ||||||
|         case "KANJIA": |         case "KANJIA": | ||||||
|           this.$navigateTo({ |           uni.navigateTo({ | ||||||
|             url: `/pages/promotion/bargain/list`, |             url: `/pages/promotion/bargain/list`, | ||||||
|           }); |           }); | ||||||
|           break; |           break; | ||||||
|  |  | ||||||
|  | @ -12,7 +12,7 @@ export default { | ||||||
|   props: ["res"], |   props: ["res"], | ||||||
|   methods: { |   methods: { | ||||||
|     handleSearch() { |     handleSearch() { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: "/pages/navigation/search/searchPage", |         url: "/pages/navigation/search/searchPage", | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -150,18 +150,18 @@ export default { | ||||||
|           // WX_CODE 为小程序码 |           // WX_CODE 为小程序码 | ||||||
|           if (res.scanType == "WX_CODE") { |           if (res.scanType == "WX_CODE") { | ||||||
|             console.log(res); |             console.log(res); | ||||||
|             this.$navigateTo({ |             uni.navigateTo({ | ||||||
|               url: `/${res.path}`, |               url: `/${res.path}`, | ||||||
|             }); |             }); | ||||||
|           } else { |           } else { | ||||||
|             config.scanAuthNavigation.forEach((src) => { |             config.scanAuthNavigation.forEach((src) => { | ||||||
|               if (res.result.indexOf(src) != -1) { |               if (res.result.indexOf(src) != -1) { | ||||||
|                 this.$navigateTo({ |                 uni.navigateTo({ | ||||||
|                   url: `/${res.result.substring(src.length)}`, |                   url: `/${res.result.substring(src.length)}`, | ||||||
|                 }); |                 }); | ||||||
|               } else { |               } else { | ||||||
|                 setTimeout(() => { |                 setTimeout(() => { | ||||||
|                   this.$navigateTo({ |                   uni.navigateTo({ | ||||||
|                     url: "/pages/tabbar/home/web-view?src=" + path, |                     url: "/pages/tabbar/home/web-view?src=" + path, | ||||||
|                   }); |                   }); | ||||||
|                 }, 100); |                 }, 100); | ||||||
|  |  | ||||||
|  | @ -45,14 +45,14 @@ export default { | ||||||
|   //   }, |   //   }, | ||||||
|   methods: { |   methods: { | ||||||
|     gotoLink() { |     gotoLink() { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         //点击跳转到浏览器 |         //点击跳转到浏览器 | ||||||
|         url: |         url: | ||||||
|           "/pages/tabbar/home/web-view?src=https://pc-b2b2c.pickmall.cn/article/detail?id=1371992704333905920", |           "/pages/tabbar/home/web-view?src=https://pc-b2b2c.pickmall.cn/article/detail?id=1371992704333905920", | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|     gotoB() { |     gotoB() { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url: |         url: | ||||||
|           "/pages/tabbar/home/web-view?src=https://pc-b2b2c.pickmall.cn/article/detail?id=1371779927900160000", |           "/pages/tabbar/home/web-view?src=https://pc-b2b2c.pickmall.cn/article/detail?id=1371779927900160000", | ||||||
|       }); |       }); | ||||||
|  |  | ||||||
|  | @ -122,7 +122,7 @@ export default { | ||||||
|      * navigator标签现在默认没有转场动画,所以用view |      * navigator标签现在默认没有转场动画,所以用view | ||||||
|      */ |      */ | ||||||
|     navigateTo(url) { |     navigateTo(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  |  | ||||||
|  | @ -73,7 +73,7 @@ | ||||||
| 				}) | 				}) | ||||||
| 			}, | 			}, | ||||||
| 			goDetail(item) { | 			goDetail(item) { | ||||||
| 				this.$navigateTo({ | 				uni.navigateTo({ | ||||||
| 					url: '/pages/product/goods?id=' + item.content.id + "&goodsId=" +item.content.goodsId | 					url: '/pages/product/goods?id=' + item.content.id + "&goodsId=" +item.content.goodsId | ||||||
| 				}) | 				}) | ||||||
| 			}, | 			}, | ||||||
|  |  | ||||||
|  | @ -69,7 +69,7 @@ import { distribution } from "@/api/goods"; | ||||||
| export default { | export default { | ||||||
|   methods: { |   methods: { | ||||||
|     navigateTo(url) { |     navigateTo(url) { | ||||||
|       this.$navigateTo({ |       uni.navigateTo({ | ||||||
|         url, |         url, | ||||||
|       }); |       }); | ||||||
|     }, |     }, | ||||||
|  | @ -78,11 +78,11 @@ export default { | ||||||
|         if (res.data.result) { |         if (res.data.result) { | ||||||
|           let type = res.data.result.distributionStatus; |           let type = res.data.result.distributionStatus; | ||||||
|           if (type == "PASS") { |           if (type == "PASS") { | ||||||
|             this.$navigateTo({ |             uni.navigateTo({ | ||||||
|               url: "/pages/mine/distribution/home", |               url: "/pages/mine/distribution/home", | ||||||
|             }); |             }); | ||||||
|           } else if (type == "REFUSE") { |           } else if (type == "REFUSE") { | ||||||
|             this.$navigateTo({ |             uni.navigateTo({ | ||||||
|               url: "/pages/mine/distribution/auth", |               url: "/pages/mine/distribution/auth", | ||||||
|             }); |             }); | ||||||
|           } else if (type == "RETREAT") { |           } else if (type == "RETREAT") { | ||||||
|  | @ -106,7 +106,7 @@ export default { | ||||||
|           }); |           }); | ||||||
|         } else { |         } else { | ||||||
|           // 没有资格申请 先去实名认证 |           // 没有资格申请 先去实名认证 | ||||||
|           this.$navigateTo({ |           uni.navigateTo({ | ||||||
|             url: "/pages/mine/distribution/auth", |             url: "/pages/mine/distribution/auth", | ||||||
|           }); |           }); | ||||||
|         } |         } | ||||||
|  |  | ||||||
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 5.2 KiB | 
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 19 KiB | 
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 6.7 KiB | 
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 1.4 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 692 B | 
							
								
								
									
										3
									
								
								uni.scss
								
								
								
								
							
							
						
						
									
										3
									
								
								uni.scss
								
								
								
								
							|  | @ -149,6 +149,9 @@ $font-weight: 400; | ||||||
| } | } | ||||||
| .flex-a-c{ | .flex-a-c{ | ||||||
| 	align-items: center; | 	align-items: center; | ||||||
|  | } | ||||||
|  | .flex-j-sb{ | ||||||
|  | 	justify-content: space-between; | ||||||
| } | } | ||||||
| .relative { | .relative { | ||||||
| 	position: relative; | 	position: relative; | ||||||
|  |  | ||||||
|  | @ -1,5 +1,7 @@ | ||||||
| import Foundation from "./Foundation.js"; | import Foundation from "./Foundation.js"; | ||||||
| import storage from "@/utils/storage.js"; | import storage from "@/utils/storage.js"; | ||||||
|  | import { getUserInfo } from '@/api/members'; | ||||||
|  | import Vue from "vue"; | ||||||
| /** | /** | ||||||
|  * 金钱单位置换  2999 --> 2,999.00 |  * 金钱单位置换  2999 --> 2,999.00 | ||||||
|  * @param val |  * @param val | ||||||
|  | @ -99,12 +101,46 @@ export function clearStrComma(str) { | ||||||
| export function isLogin(val) { | export function isLogin(val) { | ||||||
|   let userInfo = storage.getUserInfo(); |   let userInfo = storage.getUserInfo(); | ||||||
|   if (val == "auth") { |   if (val == "auth") { | ||||||
|     return userInfo.id ? true : false; |     return userInfo && userInfo.id ? true : false; | ||||||
|   } else { |   } else { | ||||||
|     return storage.getUserInfo(); |     return storage.getUserInfo(); | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  | export function tipsToLogin(){ | ||||||
|  | if(!isLogin('auth')){ | ||||||
|  |   uni.showModal({ | ||||||
|  |     title: "提示", | ||||||
|  |     content: "当前用户未登录是否登录?", | ||||||
|  |     confirmText: "确定", | ||||||
|  |     cancelText: "取消", | ||||||
|  |     confirmColor:Vue.prototype.$mainColor, | ||||||
|  |     success: res => { | ||||||
|  |       if (res.confirm) { | ||||||
|  |         navigateToLogin() | ||||||
|  |       } else if (res.cancel) { | ||||||
|  |         uni.navigateBack() | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|  |   }) | ||||||
|  |     return | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /** | ||||||
|  |  * 获取用户信息并重新添加到缓存里面 | ||||||
|  |  */ | ||||||
|  | export async function userInfo(){ | ||||||
|  | 	let res = await getUserInfo(); | ||||||
|  | 	if(res.data.success){ | ||||||
|  | 		storage.setUserInfo(res.data.result); | ||||||
|  | 		return res.data.result  | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /** | /** | ||||||
|  * 验证是否登录如果没登录则去登录 |  * 验证是否登录如果没登录则去登录 | ||||||
|  * @param {*} val |  * @param {*} val | ||||||
|  | @ -113,7 +149,7 @@ export function isLogin(val) { | ||||||
| 
 | 
 | ||||||
| export function forceLogin() { | export function forceLogin() { | ||||||
|   let userInfo = storage.getUserInfo(); |   let userInfo = storage.getUserInfo(); | ||||||
|   if (!userInfo.id) { |   if (!userInfo ||  !userInfo.id) { | ||||||
|     // #ifdef MP-WEIXIN
 |     // #ifdef MP-WEIXIN
 | ||||||
| 
 | 
 | ||||||
|     uni.navigateTo({ |     uni.navigateTo({ | ||||||
|  |  | ||||||
|  | @ -1,24 +0,0 @@ | ||||||
| export function navigateTo({url}) { |  | ||||||
|   // #ifdef MP-WEIXIN
 |  | ||||||
|   //判断当前页面栈的长度
 |  | ||||||
|   if (getCurrentPages().length >= 8) { |  | ||||||
|     //超过八层的时候跳转销毁当前页面,十层的时候手机应该会很卡;
 |  | ||||||
|     uni.redirectTo({ |  | ||||||
|       url: url, |  | ||||||
|       success: function (res) {}, |  | ||||||
|       fail: function (res) {}, |  | ||||||
|       complete: function (res) {}, |  | ||||||
|     }); |  | ||||||
|   } else { |  | ||||||
|     uni.navigateTo({ |  | ||||||
|       url: url, |  | ||||||
|     }); |  | ||||||
|   } |  | ||||||
|   //   #endif
 |  | ||||||
| 
 |  | ||||||
|   //   #ifndef MP-WEIXIN
 |  | ||||||
|   uni.navigateTo({ |  | ||||||
|     url: url, |  | ||||||
|   }); |  | ||||||
|   // #endif
 |  | ||||||
| } |  | ||||||
							
								
								
									
										398
									
								
								utils/request.js
								
								
								
								
							
							
						
						
									
										398
									
								
								utils/request.js
								
								
								
								
							|  | @ -1,194 +1,206 @@ | ||||||
| import Request from "@/lib/request/index.js"; | import Request from "@/lib/request/index.js"; | ||||||
| import { refreshTokenFn } from "@/api/login.js"; | import { | ||||||
| import storage from "@/utils/storage.js"; | 	refreshTokenFn | ||||||
| import { md5 } from "@/utils/md5.js"; | } from "@/api/login.js"; | ||||||
| import Foundation from "@/utils/Foundation.js"; | import storage from "@/utils/storage.js"; | ||||||
| import api from "@/config/api.js"; | import { | ||||||
| 
 | 	md5 | ||||||
| import uuid from "@/utils/uuid.modified.js"; | } from "@/utils/md5.js"; | ||||||
| 
 | import Foundation from "@/utils/Foundation.js"; | ||||||
| 
 | import api from "@/config/api.js"; | ||||||
| let isNavigateTo = false | 
 | ||||||
| 
 | import uuid from "@/utils/uuid.modified.js"; | ||||||
| function cleanStorage() { | 
 | ||||||
|   uni.showToast({ | 
 | ||||||
|     title: "你的登录状态已过期,请重新登录", | let isNavigateTo = false | ||||||
|     icon: "none", | 
 | ||||||
|     duration: 1500, | function cleanStorage() { | ||||||
|   }); | 	uni.showToast({ | ||||||
|   if (uni.showLoading()) { | 		title: "你的登录状态已过期,请重新登录", | ||||||
|     uni.hideLoading(); | 		icon: "none", | ||||||
|   } | 		duration: 1500, | ||||||
| 
 | 	}); | ||||||
|   storage.setHasLogin(false); | 	if (uni.showLoading()) { | ||||||
|   storage.setAccessToken(""); | 		uni.hideLoading(); | ||||||
|   storage.setRefreshToken(""); | 	} | ||||||
|   console.log("清空token"); | 
 | ||||||
|   storage.setUuid(""); | 	storage.setHasLogin(false); | ||||||
|   storage.setUserInfo({}); | 	storage.setAccessToken(""); | ||||||
| 
 | 	storage.setRefreshToken(""); | ||||||
| 	 | 	console.log("清空token"); | ||||||
|   if(!isNavigateTo){ | 	storage.setUuid(""); | ||||||
| 	  isNavigateTo= true | 	storage.setUserInfo({}); | ||||||
| 	  // 防抖处理跳转
 | 
 | ||||||
| 	  // #ifdef MP-WEIXIN
 | 
 | ||||||
| 	  uni.navigateTo({ | 	if (!isNavigateTo) { | ||||||
| 		url: "/pages/passport/wechatMPLogin", | 		isNavigateTo = true | ||||||
| 	  }); | 		// 防抖处理跳转
 | ||||||
| 	  // #endif
 | 		// #ifdef MP-WEIXIN
 | ||||||
| 	  // #ifndef MP-WEIXIN
 | 		uni.navigateTo({ | ||||||
| 	  uni.navigateTo({ | 			url: "/pages/passport/wechatMPLogin", | ||||||
| 		url: "/pages/passport/login", | 		}); | ||||||
| 	  }); | 		// #endif
 | ||||||
|   //  #endif
 | 		// #ifndef MP-WEIXIN
 | ||||||
|   } | 		uni.navigateTo({ | ||||||
| } | 			url: "/pages/passport/login", | ||||||
| 
 | 		}); | ||||||
| let http = new Request(); | 		//  #endif
 | ||||||
| 
 | 	} | ||||||
| 
 | } | ||||||
| http.setConfig((config) => { | 
 | ||||||
|   // 没有uuid创建
 | let http = new Request(); | ||||||
|   if (!storage.getUuid()) { | 
 | ||||||
|     storage.setUuid(uuid.v1()); | 
 | ||||||
|   } | http.setConfig((config) => { | ||||||
| 
 | 	// 没有uuid创建
 | ||||||
|   /* 设置全局配置 */ | 	if (!storage.getUuid()) { | ||||||
|   config.baseURL = api.buyer; | 		storage.setUuid(uuid.v1()); | ||||||
|   config.header = { | 	} | ||||||
|     ...config.header, | 
 | ||||||
|   }; | 	/* 设置全局配置 */ | ||||||
|   config.validateStatus = (statusCode) => { | 	config.baseURL = api.buyer; | ||||||
|     // 不论什么状态,统一在正确中处理
 | 	config.header = { | ||||||
|     return true; | 		...config.header, | ||||||
|   }; | 	}; | ||||||
|   return config; | 	config.validateStatus = (statusCode) => { | ||||||
| }); | 		// 不论什么状态,统一在正确中处理
 | ||||||
| 
 | 		return true; | ||||||
| http.interceptors.request.use( | 	}; | ||||||
|   (config) => { | 	return config; | ||||||
|     /* 请求之前拦截器。可以使用async await 做异步操作 */ | }); | ||||||
|     let accessToken = storage.getAccessToken(); | 
 | ||||||
|     if (accessToken) { | http.interceptors.request.use( | ||||||
|       const nonce = Foundation.randomString(6); | 	(config) => { | ||||||
|       const timestamp = parseInt(new Date().getTime() / 1000); | 		/* 请求之前拦截器。可以使用async await 做异步操作 */ | ||||||
|       const sign = md5(nonce + timestamp + accessToken); | 		let accessToken = storage.getAccessToken(); | ||||||
|       const _params = { | 		if (accessToken) { | ||||||
|         nonce, | 			const nonce = Foundation.randomString(6); | ||||||
|         timestamp, | 			const timestamp = parseInt(new Date().getTime() / 1000); | ||||||
|         sign, | 			const sign = md5(nonce + timestamp + accessToken); | ||||||
|       }; | 			const _params = { | ||||||
|       let params = config.params || {}; | 				nonce, | ||||||
|       params = { ...params, ..._params }; | 				timestamp, | ||||||
| 
 | 				sign, | ||||||
|       config.params = params; | 			}; | ||||||
|       config.header.accessToken = accessToken; | 			let params = config.params || {}; | ||||||
| 
 | 			params = { | ||||||
|        | 				...params, | ||||||
|     } | 				..._params | ||||||
|     config.header = { | 			}; | ||||||
|       ...config.header, | 
 | ||||||
|       uuid: storage.getUuid() || uuid.v1(), | 			config.params = params; | ||||||
|     }; | 			config.header.accessToken = accessToken; | ||||||
|     return config; | 
 | ||||||
|   }, | 
 | ||||||
|   (config) => { | 		} | ||||||
|     return Promise.reject(config); | 		config.header = { | ||||||
|   } | 			...config.header, | ||||||
| ); | 			uuid: storage.getUuid() || uuid.v1(), | ||||||
| 
 | 		}; | ||||||
| 
 | 		return config; | ||||||
| // 是否正在刷新的标记
 | 	}, | ||||||
| let isRefreshing = false; | 	(config) => { | ||||||
| //重试队列
 | 		return Promise.reject(config); | ||||||
| let requests = []; | 	} | ||||||
| // 必须使用异步函数,注意
 | ); | ||||||
| http.interceptors.response.use( | 
 | ||||||
|   async (response) => { | 
 | ||||||
| 	isNavigateTo = false | // 是否正在刷新的标记
 | ||||||
|     /* 请求之后拦截器。可以使用async await 做异步操作  */ | let isRefreshing = false; | ||||||
|     // token存在并且token过期
 | //重试队列
 | ||||||
|     // if (isRefreshing && response.statusCode === 403) {
 | let requests = []; | ||||||
|     //   cleanStorage();
 | // 必须使用异步函数,注意
 | ||||||
|     //   isRefreshing = false;
 | http.interceptors.response.use( | ||||||
|     // }
 | 	async (response) => { | ||||||
|      | 			isNavigateTo = false | ||||||
|     let token = storage.getAccessToken(); | 			/* 请求之后拦截器。可以使用async await 做异步操作  */ | ||||||
|     if ( | 			// token存在并且token过期
 | ||||||
|       (token && response.statusCode === 403) || | 			// if (isRefreshing && response.statusCode === 403) {
 | ||||||
|       response.data.status === 403 | 			//   cleanStorage();
 | ||||||
|     ) { | 			//   isRefreshing = false;
 | ||||||
|       if (!isRefreshing) { | 			// }
 | ||||||
| 		console.log('旧token',token)  | 
 | ||||||
|         isRefreshing = true; | 			let token = storage.getAccessToken(); | ||||||
| 				storage.setAccessToken('') | 			if ( | ||||||
| 		let oldRefreshToken = storage.getRefreshToken(); | 				(token && response.statusCode === 403) || | ||||||
|         //调用刷新token的接口
 | 				response.data.status === 403 | ||||||
|         return refreshTokenFn(oldRefreshToken) | 			) { | ||||||
|           .then((res) => { | 				if (!isRefreshing) { | ||||||
|             let { accessToken, refreshToken } = res.data.result; | 					console.log('旧token', token) | ||||||
|             storage.setAccessToken(accessToken); | 					isRefreshing = true; | ||||||
|             storage.setRefreshToken(refreshToken); | 					storage.setAccessToken('') | ||||||
| 
 | 					let oldRefreshToken = storage.getRefreshToken(); | ||||||
|             response.header.accessToken = `${accessToken}`; | 					//调用刷新token的接口
 | ||||||
|             // token 刷新后将数组的方法重新执行
 | 					return refreshTokenFn(oldRefreshToken) | ||||||
| 			console.log('接口队列',requests,'新token',accessToken)  | 						.then((res) => { | ||||||
|             requests.forEach((cb) => cb(accessToken)); | 							let { | ||||||
|             requests = []; // 重新请求完清空
 | 								accessToken, | ||||||
|             return http.request(response.config); | 								refreshToken | ||||||
|           }) | 							} = res.data.result; | ||||||
|           .catch((err) => { | 							storage.setAccessToken(accessToken); | ||||||
| 			console.log('刷新token报错'+oldRefreshToken,err) | 							storage.setRefreshToken(refreshToken); | ||||||
|             cleanStorage(); | 
 | ||||||
|             return Promise.reject(err); | 							response.header.accessToken = `${accessToken}`; | ||||||
|           }) | 							// token 刷新后将数组的方法重新执行
 | ||||||
|           .finally(() => { | 							console.log('接口队列', requests, '新token', accessToken) | ||||||
|             isRefreshing = false; | 							requests.forEach((cb) => cb(accessToken)); | ||||||
|           }); | 							requests = []; // 重新请求完清空
 | ||||||
|       } else { | 							return http.request(response.config); | ||||||
|         // 返回未执行 resolve 的 Promise
 | 						}) | ||||||
|         return new Promise((resolve) => { | 						.catch((err) => { | ||||||
|           // 用函数形式将 resolve 存入,等待刷新后再执行
 | 							console.log('刷新token报错' + oldRefreshToken, err) | ||||||
|           requests.push((token) => { | 							cleanStorage(); | ||||||
|             response.header.accessToken = `${token}`; | 							return Promise.reject(err); | ||||||
|             resolve(http.request(response.config)); | 						}) | ||||||
|           }); | 						.finally(() => { | ||||||
|         }); | 							isRefreshing = false; | ||||||
|       } | 						}); | ||||||
| 
 | 				} else { | ||||||
|       // 如果当前返回没登录
 | 					// 返回未执行 resolve 的 Promise
 | ||||||
|     } else if ( | 					return new Promise((resolve) => { | ||||||
|       (!token && !storage.getRefreshToken() && response.statusCode === 403) || | 						// 用函数形式将 resolve 存入,等待刷新后再执行
 | ||||||
|       response.data.code === 403 | 						requests.push((token) => { | ||||||
|     ) { | 							response.header.accessToken = `${token}`; | ||||||
| 	  console.log('没有token 以及刷新token 内容',token,storage.getRefreshToken()) | 							resolve(http.request(response.config)); | ||||||
|       cleanStorage(); | 						}); | ||||||
| 
 | 					}); | ||||||
|       // 如果当前状态码为正常但是success为不正常时
 | 				} | ||||||
|     } else if ( | 
 | ||||||
|       (response.statusCode == 200 && !response.data.success) || | 				// 如果当前返回没登录
 | ||||||
|       response.statusCode == 400 | 			} else if ( | ||||||
|     ) { | 				(!token && !storage.getRefreshToken() && response.statusCode === 403) || | ||||||
|       if (response.data.message) { | 				response.data.code === 403 | ||||||
|         uni.showToast({ | 			) { | ||||||
|           title: response.data.message, | 				console.log('没有token 以及刷新token 内容', token, storage.getRefreshToken()) | ||||||
|           icon: "none", | 				cleanStorage(); | ||||||
|           duration: 1500, | 
 | ||||||
|         }); | 				// 如果当前状态码为正常但是success为不正常时
 | ||||||
|       } | 			} else if ( | ||||||
|     } | 				(response.statusCode == 200 && !response.data.success) || | ||||||
|     return response; | 				response.statusCode == 400 | ||||||
|   }, | 			) { | ||||||
|   (error) => { | 				if (response.data.message) { | ||||||
|     return error; | 					uni.showToast({ | ||||||
|   } | 						title: response.data.message, | ||||||
| ); | 						icon: "none", | ||||||
| 
 | 						duration: 1500, | ||||||
| export { http }; | 					}); | ||||||
| 
 | 				} | ||||||
| export const Method = { | 			} | ||||||
|   GET: "GET", | 			return response; | ||||||
|   POST: "POST", | 		}, | ||||||
|   PUT: "PUT", | 		(error) => { | ||||||
|   DELETE: "DELETE", | 			return error; | ||||||
|  | 		} | ||||||
|  | ); | ||||||
|  | 
 | ||||||
|  | export { | ||||||
|  | 	http | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | export const Method = { | ||||||
|  | 	GET: "GET", | ||||||
|  | 	POST: "POST", | ||||||
|  | 	PUT: "PUT", | ||||||
|  | 	DELETE: "DELETE", | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -215,7 +215,7 @@ | ||||||
| 				if (jump) { | 				if (jump) { | ||||||
| 					// #ifdef MP | 					// #ifdef MP | ||||||
| 					if (attrs['app-id']) { | 					if (attrs['app-id']) { | ||||||
| 						return this.$navigateToMiniProgram({ | 						return uni.navigateToMiniProgram({ | ||||||
| 							appId: attrs['app-id'], | 							appId: attrs['app-id'], | ||||||
| 							path: attrs.path | 							path: attrs.path | ||||||
| 						}) | 						}) | ||||||
|  | @ -241,7 +241,7 @@ | ||||||
| 							}) | 							}) | ||||||
| 							// #endif | 							// #endif | ||||||
| 						} else | 						} else | ||||||
| 							this.$navigateTo({ | 							uni.navigateTo({ | ||||||
| 								url: attrs.href, | 								url: attrs.href, | ||||||
| 								fail() { | 								fail() { | ||||||
| 									uni.switchTab({ | 									uni.switchTab({ | ||||||
|  |  | ||||||
|  | @ -331,7 +331,7 @@ | ||||||
| 							} else if (href.indexOf('http') == 0 || href.indexOf('//') == 0) | 							} else if (href.indexOf('http') == 0 || href.indexOf('//') == 0) | ||||||
| 								return true; | 								return true; | ||||||
| 							else | 							else | ||||||
| 								this.$navigateTo({ | 								uni.navigateTo({ | ||||||
| 									url: href | 									url: href | ||||||
| 								}) | 								}) | ||||||
| 						} | 						} | ||||||
|  | @ -578,7 +578,7 @@ | ||||||
| 							} else if (href.includes('://')) | 							} else if (href.includes('://')) | ||||||
| 								plus.runtime.openWeb(href); | 								plus.runtime.openWeb(href); | ||||||
| 							else | 							else | ||||||
| 								this.$navigateTo({ | 								uni.navigateTo({ | ||||||
| 									url: href | 									url: href | ||||||
| 								}) | 								}) | ||||||
| 						} | 						} | ||||||
|  |  | ||||||
|  | @ -114,7 +114,7 @@ | ||||||
| 							url: this.config.url | 							url: this.config.url | ||||||
| 						}); | 						}); | ||||||
| 					} else { | 					} else { | ||||||
| 						this.$navigateTo({ | 						uni.navigateTo({ | ||||||
| 							url: this.config.url | 							url: this.config.url | ||||||
| 						}); | 						}); | ||||||
| 					} | 					} | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue