350 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
			
		
		
	
	
			350 lines
		
	
	
		
			7.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
| <template>
 | |
| 	<view class="product-detail pr">
 | |
| 		<view class="product-pic">
 | |
| 			<swiper class="swiper" indicator-active-color="#ffffff" indicator-color="rgba(255,255,255,.3)"
 | |
| 				indicator-dots autoplay :interval="2000" :duration="500">
 | |
| 				<swiper-item v-if="detail.picture">
 | |
| 					<image :src="detail.picture" mode="aspectFit"></image>
 | |
| 				</swiper-item>
 | |
| 			</swiper>
 | |
| 		</view>
 | |
| 		<view class="product-content">
 | |
| 			<view class="product-info">
 | |
| 				<view class="text-ellipsis-2 mb23">
 | |
| 					<!-- <text class="type-tips">爆款</text> -->
 | |
| 					<text class="f32 gray3">{{ detail.titleName }}</text>
 | |
| 				</view>
 | |
| 				<view class="f28 mb23">
 | |
| 					<text class="gray9">{{ detail.twoLevelTitle }}</text>
 | |
| 				</view>
 | |
| 			</view>
 | |
| 			<view class="secend-info">
 | |
| 				<view class="d-b-c sec-info-item">
 | |
| 					<view class="sec-info-label">{{$t("w_0122")}}</view>
 | |
| 					<view class="flex-1"></view>
 | |
| 				</view>
 | |
| 			</view>
 | |
| 			<view class="thi-info">
 | |
| 				<view class="thi-nav">
 | |
| 					<view class="thi-nav-item" :class="{ active: thiType == 0 }">{{$t("w_0124")}}</view>
 | |
| 				</view>
 | |
| 				<view v-if="thiType == 0"><u-parse :content="detail.content"></u-parse></view>
 | |
| 			</view>
 | |
| 		</view>
 | |
| 		<view class="btns-wrap">
 | |
| 			<view class="d-a-c flex-1">
 | |
| 				<view class="icon-box d-c-c" @click="gotoPage('/pages/index/index')">
 | |
| 					<button class="d-c-c d-c bg-white">
 | |
| 						<image style="width: 33rpx;height: 33rpx;margin-bottom: 10rpx;"
 | |
| 							src="/static/icon/product/home.png" mode=""></image>
 | |
| 						<text class="f20" style="height: 20rpx;line-height: 20rpx;color: #FB3024;">{{$t("ENU_MENU_10")}}</text>
 | |
| 					</button>
 | |
| 				</view>
 | |
| 				<view class="icon-box d-c-c">
 | |
| 					<button class="d-c-c d-c bg-white">
 | |
| 						<image style="width: 33rpx;height: 33rpx;margin-bottom: 10rpx;"
 | |
| 							src="/static/icon/product/service.png" mode=""></image>
 | |
| 						<text class="f20 gray3" style="height: 20rpx;line-height: 20rpx;">{{$t("w_0259")}}</text>
 | |
| 					</button>
 | |
| 				</view>
 | |
| 				<view class="icon-box d-c-c" @click="gotoPage('/pages/cart/cart')">
 | |
| 					<button class="pr d-c-c d-c bg-white">
 | |
| 						<image style="width: 33rpx;height: 33rpx;margin-bottom: 10rpx;"
 | |
| 							src="/static/icon/product/cart.png" mode=""></image>
 | |
| 						<text class="f20 gray3" style="height: 20rpx;line-height: 20rpx;">{{$t("N_I_194")}}</text>
 | |
| 					</button>
 | |
| 				</view>
 | |
| 			</view>
 | |
| 			<template>
 | |
| 				<button type="primary" class="buy one" @click="openSpec">{{$t("N_I_192")}}</button>
 | |
| 			</template>
 | |
| 		</view>
 | |
| 	</view>
 | |
| </template>
 | |
| 
 | |
| <script>
 | |
| 	export default {
 | |
| 		data() {
 | |
| 			return {
 | |
| 				pkId: 0,
 | |
| 				waresCode: '',
 | |
| 				title: '',
 | |
| 				productModel: null,
 | |
| 				isPopup: false,
 | |
| 				isTablePopup: false,
 | |
| 				isPreview: false,
 | |
| 				isVideoPlay: false,
 | |
| 				detail: {},
 | |
| 				thiType: 0,
 | |
| 				alreadyChioce: '',
 | |
| 				isFirst: true,
 | |
| 				productParams: []
 | |
| 			};
 | |
| 		},
 | |
| 		onLoad(e) {
 | |
| 			this.pkId = e.pkId;
 | |
| 			this.getData();
 | |
| 		},
 | |
| 		methods: {
 | |
| 			getData() {
 | |
| 				let self = this;
 | |
| 				uni.request({
 | |
| 					url: 'http://p1.hzs413.com/inter-api/home/api/ho-product-details/getHoWaresDetails/' +
 | |
| 						self.pkId,
 | |
| 					method: 'GET',
 | |
| 					success: result => {
 | |
| 						console.log(result);
 | |
| 						var data = result.data;
 | |
| 						self.detail = data.data;
 | |
| 						console.log(self.detail)
 | |
| 					},
 | |
| 					error: error => {
 | |
| 						console.log('----------------error');
 | |
| 						console.log(error);
 | |
| 					}
 | |
| 				});
 | |
| 			}
 | |
| 		}
 | |
| 	};
 | |
| </script>
 | |
| 
 | |
| <style lang="scss">
 | |
| 	.product-detail {
 | |
| 		padding-bottom: 150rpx;
 | |
| 	}
 | |
| 
 | |
| 	.product-detail .product-pic,
 | |
| 	.product-detail .product-pic .swiper,
 | |
| 	.product-detail .product-pic image {
 | |
| 		width: 750rpx;
 | |
| 		height: 750rpx;
 | |
| 	}
 | |
| 
 | |
| 	.product-detail .product-pic .swiper .icon-bofang {
 | |
| 		position: absolute;
 | |
| 		top: 0;
 | |
| 		bottom: 0;
 | |
| 		left: 0;
 | |
| 		right: 0;
 | |
| 		margin: auto;
 | |
| 		font-size: 48rpx;
 | |
| 		color: #ffffff;
 | |
| 		border-radius: 50%;
 | |
| 		border: 4rpx solid #ffffff;
 | |
| 		width: 120rpx;
 | |
| 		height: 120rpx;
 | |
| 		display: flex;
 | |
| 		justify-content: center;
 | |
| 		align-items: center;
 | |
| 		background-color: #00000080;
 | |
| 		padding-left: 16rpx;
 | |
| 		box-sizing: border-box;
 | |
| 		z-index: 10;
 | |
| 	}
 | |
| 
 | |
| 	.video {
 | |
| 		width: 100%;
 | |
| 		height: 100%;
 | |
| 	}
 | |
| 
 | |
| 	.product-content {
 | |
| 		padding: 22rpx 23rpx;
 | |
| 	}
 | |
| 
 | |
| 	.preview-box {
 | |
| 		width: 100%;
 | |
| 		height: 134rpx;
 | |
| 		padding: 0 20rpx;
 | |
| 		box-sizing: border-box;
 | |
| 		margin-bottom: -10rpx;
 | |
| 
 | |
| 		.preview-bg {
 | |
| 			width: 704rpx;
 | |
| 			height: 134rpx;
 | |
| 			position: absolute;
 | |
| 			left: 0;
 | |
| 			top: 0;
 | |
| 			z-index: 0;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	.product-info {
 | |
| 		width: 704rpx;
 | |
| 		background: #ffffff;
 | |
| 		border-radius: 15rpx;
 | |
| 		position: relative;
 | |
| 		z-index: 2;
 | |
| 		padding: 42rpx 20rpx 30rpx 20rpx;
 | |
| 		box-sizing: border-box;
 | |
| 		margin-bottom: 22rpx;
 | |
| 	}
 | |
| 
 | |
| 	.type-tips {
 | |
| 		font-size: 22rpx;
 | |
| 		padding: 0 17rpx;
 | |
| 		line-height: 37rpx;
 | |
| 		background-color: #fb3024;
 | |
| 		border-radius: 19rpx;
 | |
| 		color: #ffffff;
 | |
| 		margin-right: 8rpx;
 | |
| 	}
 | |
| 
 | |
| 	.sellingPoints {
 | |
| 		background: #fb3024;
 | |
| 		border-radius: 10rpx;
 | |
| 		padding: 13rpx 38rpx;
 | |
| 		font-size: 22rpx;
 | |
| 		color: #ffffff;
 | |
| 		word-break: break-all;
 | |
| 	}
 | |
| 
 | |
| 	.secend-info {
 | |
| 		width: 704rpx;
 | |
| 		padding: 0 15rpx 0 19rpx;
 | |
| 		background: #ffffff;
 | |
| 		border-radius: 15rpx;
 | |
| 		box-sizing: border-box;
 | |
| 		margin-bottom: 25rpx;
 | |
| 
 | |
| 		.sec-info-item {
 | |
| 			padding: 20rpx 0;
 | |
| 			box-sizing: border-box;
 | |
| 			min-height: 90rpx;
 | |
| 			border-bottom: 1rpx solid #eee;
 | |
| 			font-size: 28rpx;
 | |
| 
 | |
| 			.sec-info-label {
 | |
| 				max-width: 125rpx;
 | |
| 				min-width: 105rpx;
 | |
| 				flex-shrink: 0;
 | |
| 				word-break: break-all;
 | |
| 				color: #999999;
 | |
| 				margin-right: 20rpx;
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		.sec-info-item:last-child {
 | |
| 			border: none;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	.thi-info {
 | |
| 		width: 702rpx;
 | |
| 		background: #ffffff;
 | |
| 		border-radius: 20rpx;
 | |
| 		padding: 0 15rpx 15rpx 15rpx;
 | |
| 		box-sizing: border-box;
 | |
| 	}
 | |
| 
 | |
| 	.thi-nav {
 | |
| 		display: flex;
 | |
| 		justify-content: flex-start;
 | |
| 		align-items: center;
 | |
| 		overflow-x: auto;
 | |
| 		width: 100%;
 | |
| 		padding-left: 20rpx;
 | |
| 		box-sizing: border-box;
 | |
| 		border-bottom: 1rpx solid #eee;
 | |
| 		margin-bottom: 22rpx;
 | |
| 
 | |
| 		.thi-nav-item {
 | |
| 			font-size: 30rpx;
 | |
| 			color: #333;
 | |
| 			padding: 0 30rpx;
 | |
| 			height: 92rpx;
 | |
| 			line-height: 92rpx;
 | |
| 			white-space: nowrap;
 | |
| 			flex-shrink: 0;
 | |
| 			position: relative;
 | |
| 		}
 | |
| 
 | |
| 		.thi-nav-item.active::after {
 | |
| 			position: absolute;
 | |
| 			content: '';
 | |
| 			left: 0;
 | |
| 			right: 0;
 | |
| 			margin: auto;
 | |
| 			bottom: 0;
 | |
| 			width: 30%;
 | |
| 			height: 6rpx;
 | |
| 			border-radius: 4rpx;
 | |
| 			z-index: 1;
 | |
| 			background-color: #fb3024;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap {
 | |
| 		position: fixed;
 | |
| 		height: 100rpx;
 | |
| 		right: 0;
 | |
| 		bottom: 0;
 | |
| 		left: 0;
 | |
| 		display: flex;
 | |
| 		background: #ffffff;
 | |
| 		align-items: center;
 | |
| 		z-index: 97;
 | |
| 		border-top: 1rpx solid #eee;
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap .icon-box {
 | |
| 		width: 92rpx;
 | |
| 		height: 100rpx;
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap .icon-box .iconfont {
 | |
| 		font-size: 40rpx;
 | |
| 		color: #888888;
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap .icon-box .iconfont .num {
 | |
| 		position: absolute;
 | |
| 		top: 10rpx;
 | |
| 		left: 50%;
 | |
| 		height: 30rpx;
 | |
| 		min-width: 30rpx;
 | |
| 		overflow: hidden;
 | |
| 		line-height: 32rpx;
 | |
| 		border-radius: 15rpx;
 | |
| 		font-size: 20rpx;
 | |
| 		color: #ffffff;
 | |
| 		background: red;
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap button,
 | |
| 	.btns-wrap button:after {
 | |
| 		height: 100rpx;
 | |
| 		line-height: 100rpx;
 | |
| 		margin: 0;
 | |
| 		padding: 0;
 | |
| 		border-radius: 0;
 | |
| 		border: 0;
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap button.add-cart {
 | |
| 		background: $dominant-color;
 | |
| 		font-size: 28rpx;
 | |
| 		width: 214rpx;
 | |
| 		height: 75rpx;
 | |
| 		line-height: 75rpx;
 | |
| 		margin-left: 17rpx;
 | |
| 		border-radius: 40rpx 0 0 40rpx;
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap button.buy {
 | |
| 		background: #fb3024;
 | |
| 		font-size: 28rpx;
 | |
| 		width: 214rpx;
 | |
| 		height: 75rpx;
 | |
| 		line-height: 75rpx;
 | |
| 		border-radius: 0 40rpx 40rpx 0;
 | |
| 		margin-right: 25rpx;
 | |
| 	}
 | |
| 
 | |
| 	.btns-wrap button.buy.one {
 | |
| 		border-radius: 40rpx;
 | |
| 		width: 428rpx;
 | |
| 		margin-left: 30rpx;
 | |
| 	}
 | |
| 
 | |
| 	.share-icon {}
 | |
| </style> |