You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
1431 lines
30 KiB
1431 lines
30 KiB
<template>
|
|
<view class="container">
|
|
<view class="carousel">
|
|
<swiper indicator-dots circular="true" duration="400">
|
|
<swiper-item class="swiper-item" v-for="(item, index) in small" :key="index">
|
|
<view class="image-wrapper">
|
|
<image :src="item" class="loaded" mode="aspectFill"></image>
|
|
</view>
|
|
</swiper-item>
|
|
</swiper>
|
|
</view>
|
|
|
|
<view class="introduce-section">
|
|
<text class="title">{{ goods.name }}</text>
|
|
<view class="price-box">
|
|
<!-- <text class="price-tip">惠农价</text> -->
|
|
<!-- <text class="price"
|
|
v-if="goods.vipPrice && goods.vipPrice > 0">惠农价¥{{ (goods.price * goods.memberRate) / 10 }}</text> -->
|
|
<text class="price" >惠农价¥{{ goods.originalPrice }}</text>
|
|
<text class="m-price" >市场价¥{{ goods.price }}</text>
|
|
<!-- <text class="m-price" v-else-if="goods.vipPrice && goods.vipPrice > 0">市场价¥{{ goods.price }}</text> -->
|
|
<text class="price">优惠¥{{ (goods.price - goods.originalPrice) | formatNumber}}</text>
|
|
<!-- <text class="coupon-tip"
|
|
v-if="goods.memberRate && goods.memberRate != 10">会员折扣{{ goods.memberRate }}折</text> -->
|
|
</view>
|
|
<view class="bot-row">
|
|
<text>销量: {{ goods.sale }}</text>
|
|
<text>库存: {{ goods.stock }}</text>
|
|
<text>浏览量: {{ goods.hit }}</text>
|
|
</view>
|
|
</view>
|
|
<!-- <view class="share-section" @click="navToTabPageStore(goods.storeId)">
|
|
<view class="share-icon">
|
|
<text class="yticon icon-xingxing"></text>
|
|
铺
|
|
</view>
|
|
<text class="tit"></text>
|
|
<text class="yticon icon-bangzhu1"></text>
|
|
<view class="share-btn">
|
|
进入店铺
|
|
<text class="yticon icon-you"></text>
|
|
</view>
|
|
</view>
|
|
|
|
<!--分享-->
|
|
<!-- <view class="share-section" @click="share">
|
|
<view class="share-icon">
|
|
<text class="yticon icon-xingxing"></text>
|
|
返
|
|
</view>
|
|
<text class="tit">该商品分享可领49减10红包</text>
|
|
<text class="yticon icon-bangzhu1"></text>
|
|
<view class="share-btn">
|
|
立即分享
|
|
<text class="yticon icon-you"></text>
|
|
</view>
|
|
</view> -->
|
|
|
|
<!-- <view class="c-list">
|
|
<view class="c-row b-b" v-if="skuList && skuList.length > 0" @click="toggleSpec">
|
|
<text class="tit">规格</text>
|
|
<view class="con">
|
|
<text class="selected-text" v-for="(sItem, sIndex) in specSelected"
|
|
:key="sIndex">{{ sItem.name }}</text>
|
|
</view>
|
|
<text class="yticon icon-you"></text>
|
|
</view>
|
|
<view class="c-row b-b" v-if="couponList.length > 0" @click="toggleMask('show')">
|
|
<text class="tit">优惠券</text>
|
|
<text class="con t-r red">领取优惠券</text>
|
|
<text class="yticon icon-you"></text>
|
|
</view>
|
|
|
|
<view class="c-row b-b" v-if="serviceList && serviceList.length > 0">
|
|
<text class="tit">服务</text>
|
|
<view class="bz-list con">
|
|
<text v-for="(item1, index1) in serviceList" :key="index1">{{ item1 }}</text>
|
|
</view>
|
|
</view>
|
|
</view> -->
|
|
|
|
<!-- 评价 -->
|
|
<!-- <view class="eva-section">
|
|
<view class="e-header">
|
|
<text class="tit">评价</text>
|
|
<text>({{ consultCount.all }})</text>
|
|
<text class="tit">好评</text>
|
|
<text>({{ consultCount.goods }})</text>
|
|
|
|
<text class="tit">一般</text>
|
|
<text>({{ consultCount.general }})</text>
|
|
|
|
<text class="tit">差评</text>
|
|
<text>({{ consultCount.bad }})</text>
|
|
<text class="tip" v-if="consultCount.persent != 200">好评率 {{ consultCount.persent }}%</text>
|
|
<text class="yticon icon-you"></text>
|
|
</view>
|
|
<view class="eva-box" v-for="(item, index) in consultList" :key="item.id">
|
|
<image :src="item.pic" class="portrait" mode="aspectFill"></image>
|
|
<view class="right">
|
|
<text class="name">{{ item.memberName }}</text>
|
|
<text class="con">{{ item.consultContent }}</text>
|
|
<view class="bot">
|
|
<text class="attr">购买类型:{{ item.attr }}</text>
|
|
<text class="time">{{ item.consultAddtime }}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
</view> -->
|
|
|
|
<view class="detail-desc">
|
|
<view class="d-header"><text>图文详情</text></view>
|
|
<rich-text :nodes="desc | formatRichText"></rich-text>
|
|
</view>
|
|
|
|
<!-- 底部操作菜单 -->
|
|
<view class="page-bottom">
|
|
<navigator url="/pages/index/index" open-type="switchTab" class="p-b-btn">
|
|
<text class="yticon icon-xiatubiao--copy"></text>
|
|
<text>首页</text>
|
|
</navigator>
|
|
<navigator url="/pages/cart/cart" open-type="switchTab" class="p-b-btn">
|
|
<text class="yticon icon-gouwuche"></text>
|
|
<text>购物车</text>
|
|
</navigator>
|
|
<view class="p-b-btn" :class="{ active: favorite }" @click="toFavorite(goods)">
|
|
<text class="yticon icon-shoucang"></text>
|
|
<text>收藏</text>
|
|
</view>
|
|
|
|
<view class="action-btn-group">
|
|
<button type="primary" class=" action-btn no-border add-cart-btn" @click="addCart(goods)">加入购物车</button>
|
|
<button type="primary" class=" action-btn no-border buy-now-btn" @click="buy(goods)">立即购买</button>
|
|
</view>
|
|
</view>
|
|
|
|
<view class="mask" :class="maskState === 0 ? 'none' : maskState === 1 ? 'show' : ''" @click="toggleMask">
|
|
<view class="mask-content" @click.stop.prevent="stopPrevent">
|
|
<view @click="obtainCoupon(item)" class="coupon-item" v-for="(item, index) in couponList" :key="index">
|
|
<view class="con">
|
|
<view class="left">
|
|
<text class="title">{{ item.name }}</text>
|
|
<text class="time">在{{ item.endTime }}前有效。 可领{{ item.perLimit }}张</text>
|
|
</view>
|
|
<view class="right">
|
|
<text class="price">{{ item.amount }}</text>
|
|
<text>满{{ item.minPoint }}可减{{ item.amount }}</text>
|
|
</view>
|
|
<view class="circle l"></view>
|
|
<view class="circle r"></view>
|
|
</view>
|
|
<text class="tips">{{ item.categoryTitle ? '限' + item.categoryTitle + '可用' : '全品类可用' }}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
|
|
<!-- 规格-模态层弹窗 -->
|
|
<view class="popup spec" :class="specClass" @touchmove.stop.prevent="stopPrevent" @click="toggleSpec">
|
|
<!-- 遮罩层 -->
|
|
<view class="mask"></view>
|
|
<view class="layer attr-content" @click.stop="stopPrevent">
|
|
<view class="a-t">
|
|
<image :src="sku.pic"></image>
|
|
<view class="right">
|
|
<text class="price">¥{{ (sku.price * goods.memberRate) / 10 }} 原价 ¥{{ sku.price }}</text>
|
|
<text class="stock">库存:{{ sku.stock }}件</text>
|
|
<view class="selected">
|
|
已选:
|
|
<text class="selected-text" v-for="(sItem, sIndex) in specSelected"
|
|
:key="sIndex">{{ sItem.name }}</text>
|
|
</view>
|
|
</view>
|
|
</view>
|
|
<view v-for="(item, index) in specList" :key="index" class="attr-list">
|
|
<text>{{ item.name }}</text>
|
|
<view class="item-list">
|
|
<text v-for="(childItem, childIndex) in specChildList" v-if="childItem.pid === item.id"
|
|
:key="childIndex" class="tit" :class="{ selected: childItem.selected }"
|
|
@click="selectSpec(childIndex, childItem.pid)">
|
|
{{ childItem.name }}
|
|
</text>
|
|
</view>
|
|
</view>
|
|
<button class="btn" @click="toggleSpec">完成</button>
|
|
</view>
|
|
</view>
|
|
<!-- 分享 -->
|
|
<share ref="share" :contentHeight="580" :shareList="shareList"></share>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import mallplusCopyright from '@/components/mall-copyright/mallplusCopyright.vue';
|
|
import Api from '@/common/api';
|
|
import share from '@/components/share';
|
|
import {
|
|
mapState
|
|
} from 'vuex';
|
|
import {
|
|
formatDate
|
|
} from '@/common/date';
|
|
|
|
export default {
|
|
components: {
|
|
share
|
|
},
|
|
data() {
|
|
return {
|
|
maskState: 0, //优惠券面板显示状态
|
|
specClass: 'none',
|
|
specSelected: [],
|
|
small: null,
|
|
sku: [],
|
|
detailData: [],
|
|
serviceList: [],
|
|
goods: [],
|
|
favorite: true,
|
|
shareList: [],
|
|
consultList: [],
|
|
couponList: [],
|
|
basicMarkingList: [],
|
|
basicGiftsList: [],
|
|
consultCount: {
|
|
all: 0,
|
|
bad: 0,
|
|
general: 0,
|
|
goods: 0
|
|
},
|
|
imgList: [{
|
|
src: 'https://gd3.alicdn.com/imgextra/i3/0/O1CN01IiyFQI1UGShoFKt1O_!!0-item_pic.jpg_400x400.jpg'
|
|
},
|
|
{
|
|
src: 'https://gd3.alicdn.com/imgextra/i3/TB1RPFPPFXXXXcNXpXXXXXXXXXX_!!0-item_pic.jpg_400x400.jpg'
|
|
},
|
|
{
|
|
src: 'https://gd2.alicdn.com/imgextra/i2/38832490/O1CN01IYq7gu1UGShvbEFnd_!!38832490.jpg_400x400.jpg'
|
|
}
|
|
],
|
|
desc: '',
|
|
skuList: [],
|
|
specList: [],
|
|
specChildList: []
|
|
};
|
|
},
|
|
async onLoad(ops) {
|
|
//接收传值,id里面放的是标题,因为测试数据并没写id
|
|
let id = ops.id;
|
|
if (id) {
|
|
this.logining = true;
|
|
let params = {
|
|
id: ops.id
|
|
};
|
|
let data = await Api.apiCall('get', Api.goods.goodsDetail, params);
|
|
this.logining = false;
|
|
|
|
if (data) {
|
|
let detailData = data.goods;
|
|
let goods = detailData.goods;
|
|
this.goods = goods;
|
|
this.favorite = data.favorite;
|
|
this.typeGoodsList = detailData.typeGoodsList;
|
|
var subImages = goods.albumPics;
|
|
this.desc = goods.detailHtml;
|
|
this.small = subImages.split(',');
|
|
//await this.$api.json('detailData');
|
|
let shareList = await this.$api.json('shareList');
|
|
this.loaded = true;
|
|
|
|
var sers = goods.serviceIds;
|
|
if (sers && sers.indexOf('1') != -1) {
|
|
this.serviceList.push('无忧退货');
|
|
}
|
|
if (sers && sers.indexOf('2') != -1) {
|
|
this.serviceList.push('快速退款');
|
|
}
|
|
if (sers && sers.indexOf('3') != -1) {
|
|
this.serviceList.push('正品保证');
|
|
}
|
|
this.shareList = shareList;
|
|
this.specList = detailData.productAttributeValueList;
|
|
this.skuList = detailData.skuStockList;
|
|
if (this.specList) {
|
|
this.specList.forEach(item => {
|
|
let valuesA = item.value.split(',');
|
|
if (valuesA) {
|
|
for (let cItem of valuesA) {
|
|
let att = {};
|
|
att.pid = item.id;
|
|
att.name = cItem;
|
|
this.specChildList.push(att);
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
uni.setNavigationBarTitle({
|
|
title: goods.name
|
|
});
|
|
}
|
|
if (this.hasLogin) {
|
|
let params = {
|
|
goodsId: ops.id,
|
|
pic: this.goods.pic
|
|
};
|
|
await Api.apiCall('post', Api.goods.addView, params);
|
|
}
|
|
let params1 = {
|
|
goodsId: ops.id
|
|
};
|
|
let consoltL = await Api.apiCall('get', Api.goods.consultList, params1);
|
|
this.consultList = consoltL.list;
|
|
this.consultCount = consoltL.count;
|
|
|
|
let params3 = {};
|
|
let couponList1 = await Api.apiCall('get', Api.index.couponList, params3);
|
|
this.couponList = couponList1;
|
|
}
|
|
|
|
//规格 默认选中第一条
|
|
if (this.specList) {
|
|
var specs = '';
|
|
this.specList.forEach(item => {
|
|
for (let cItem of this.specChildList) {
|
|
if (cItem.pid === item.id) {
|
|
this.$set(cItem, 'selected', true);
|
|
this.specSelected.push(cItem);
|
|
specs = cItem.name + ',' + specs;
|
|
break; //forEach不能使用break
|
|
}
|
|
}
|
|
});
|
|
let valuesA = specs.substr(0, specs.length - 1).split(',');
|
|
|
|
this.skuList.forEach(item => {
|
|
if (valuesA.length == 1 && item.sp1 == valuesA[0]) {
|
|
this.sku = item;
|
|
}
|
|
if (valuesA.length == 2 && item.sp2 == valuesA[0] && item.sp1 == valuesA[1]) {
|
|
this.sku = item;
|
|
}
|
|
if (valuesA.length == 3 && item.sp3 == valuesA[0] && item.sp2 == valuesA[1] && item.sp1 ==
|
|
valuesA[2]) {
|
|
this.sku = item;
|
|
}
|
|
if (!this.sku.pic) {
|
|
this.sku.pic = this.goods.pic;
|
|
}
|
|
if (!this.sku.stock) {
|
|
this.sku.stock = 0;
|
|
}
|
|
this.goods.price = this.sku.price;
|
|
});
|
|
}
|
|
},
|
|
computed: {
|
|
...mapState(['hasLogin', 'userInfo'])
|
|
},
|
|
filters: {
|
|
/**
|
|
* 处理富文本里的图片宽度自适应
|
|
* 1.去掉img标签里的style、width、height属性
|
|
* 2.img标签添加style属性:max-width:100%;height:auto
|
|
* 3.修改所有style里的width属性为max-width:100%
|
|
* 4.去掉<br/>标签
|
|
* @param html
|
|
* @returns {void|string|*}
|
|
*/
|
|
formatRichText(html) {
|
|
//控制小程序中图片大小
|
|
if (html) {
|
|
let newContent = html.replace(/<img[^>]*>/gi, function(match, capture) {
|
|
match = match.replace(/style="[^"]+"/gi, '').replace(/style='[^']+'/gi, '');
|
|
match = match.replace(/width="[^"]+"/gi, '').replace(/width='[^']+'/gi, '');
|
|
match = match.replace(/height="[^"]+"/gi, '').replace(/height='[^']+'/gi, '');
|
|
return match;
|
|
});
|
|
newContent = newContent.replace(/style="[^"]+"/gi, function(match, capture) {
|
|
match = match.replace(/width:[^;]+;/gi, 'max-width:100%;').replace(/width:[^;]+;/gi,
|
|
'max-width:100%;');
|
|
return match;
|
|
});
|
|
newContent = newContent.replace(/<br[^>]*\/>/gi, '');
|
|
newContent = newContent.replace(/\<img/gi,
|
|
'<img style="max-width:100%;height:auto;display:inline-block;margin:10rpx auto;"');
|
|
return newContent;
|
|
} else {
|
|
return '暂无商品详情';
|
|
}
|
|
},
|
|
formatCreateTime(time) {
|
|
let date = new Date(time);
|
|
return formatDate(date, 'yyyy-MM-dd hh:mm:ss');
|
|
},
|
|
|
|
formatNumber(number) {
|
|
return new Number(number).toFixed(2);
|
|
}
|
|
},
|
|
methods: {
|
|
navToTabPageStore(item) {
|
|
let id = item;
|
|
uni.navigateTo({
|
|
url: `../../pagesC/store/store?id=${id}`
|
|
});
|
|
},
|
|
toggleMask(type) {
|
|
let timer = type === 'show' ? 10 : 300;
|
|
let state = type === 'show' ? 1 : 0;
|
|
this.maskState = 2;
|
|
setTimeout(() => {
|
|
this.maskState = state;
|
|
}, timer);
|
|
},
|
|
//领取优惠券
|
|
async obtainCoupon(index) {
|
|
if (!this.hasLogin) {
|
|
this.$api.msg('请先登录');
|
|
}
|
|
uni.showLoading({
|
|
title: '请稍后'
|
|
});
|
|
|
|
let params = {
|
|
couponId: index.id
|
|
};
|
|
let data = await Api.apiCall('post', Api.index.acceptCoupon, params);
|
|
console.log(data);
|
|
if (data) {
|
|
this.$api.msg(data);
|
|
this.toggleMask();
|
|
}
|
|
uni.hideLoading();
|
|
},
|
|
//规格弹窗开关
|
|
toggleSpec() {
|
|
if (this.specClass === 'show') {
|
|
this.specClass = 'hide';
|
|
setTimeout(() => {
|
|
this.specClass = 'none';
|
|
}, 250);
|
|
} else if (this.specClass === 'none') {
|
|
this.specClass = 'show';
|
|
}
|
|
},
|
|
//选择规格
|
|
selectSpec(index, pid) {
|
|
let list = this.specChildList;
|
|
list.forEach(item => {
|
|
if (item.pid === pid) {
|
|
this.$set(item, 'selected', false);
|
|
}
|
|
});
|
|
|
|
this.$set(list[index], 'selected', true);
|
|
//存储已选择
|
|
/**
|
|
* 修复选择规格存储错误
|
|
* 将这几行代码替换即可
|
|
* 选择的规格存放在specSelected中
|
|
*/
|
|
var specs = '';
|
|
this.specSelected = [];
|
|
list.forEach(item => {
|
|
if (item.selected === true) {
|
|
this.specSelected.push(item);
|
|
specs = item.name + ',' + specs;
|
|
}
|
|
});
|
|
let valuesA = specs.substr(0, specs.length - 1).split(',');
|
|
this.sku = null;
|
|
this.skuList.forEach(item => {
|
|
if (valuesA.length == 1 && item.sp1 == valuesA[0]) {
|
|
this.sku = item;
|
|
}
|
|
if (valuesA.length == 2 && item.sp2 == valuesA[0] && item.sp1 == valuesA[1]) {
|
|
this.sku = item;
|
|
}
|
|
if (valuesA.length == 3 && item.sp3 == valuesA[0] && item.sp2 == valuesA[1] && item.sp1 ==
|
|
valuesA[2]) {
|
|
this.sku = item;
|
|
}
|
|
});
|
|
if (!this.sku) {
|
|
uni.showToast({
|
|
title: '商品不存在!'
|
|
});
|
|
}
|
|
if (!this.sku.pic) {
|
|
this.sku.pic = this.goods.pic;
|
|
}
|
|
if (!this.sku.stock) {
|
|
this.sku.stock = 0;
|
|
}
|
|
|
|
this.goods.price = this.sku.price;
|
|
|
|
console.log(this.sku);
|
|
},
|
|
//分享
|
|
share() {
|
|
var title = this.goods.name;
|
|
var imgUrl = this.small[0];
|
|
var href = 'http://www.yyundong.com:8088/h5/index.html#/pagesA/product/product?id=' + this.goods.id;
|
|
//var href = 'http://192.168.0.107:8084/#/pagesA/product/product?id=' + this.goods.id;
|
|
this.$refs.share.toggleMask(title, imgUrl, href);
|
|
},
|
|
//收藏
|
|
toFavorite(item) {
|
|
if (!this.hasLogin) {
|
|
let url = '/pages/public/login';
|
|
uni.navigateTo({
|
|
url
|
|
});
|
|
} else {
|
|
this.favorite = !this.favorite;
|
|
let params = {
|
|
objId: item.id,
|
|
type: 1,
|
|
name: item.name,
|
|
meno1: item.pic,
|
|
meno2: item.price,
|
|
meno3: item.sale
|
|
};
|
|
Api.apiCall('post', Api.goods.favoriteSave, params);
|
|
}
|
|
},
|
|
async buy(item) {
|
|
if (!this.hasLogin) {
|
|
let url = '/pages/public/login';
|
|
uni.navigateTo({
|
|
url
|
|
});
|
|
return;
|
|
}
|
|
let userInfo = uni.getStorageSync('userInfo');
|
|
if (userInfo && userInfo.storeId && userInfo.storeId == this.goods.storeId) {
|
|
uni.showToast({
|
|
title: '不能购买自己店铺的商品!'
|
|
});
|
|
return;
|
|
}
|
|
let data;
|
|
let id = item.id;
|
|
console.log(id);
|
|
if (this.sku && this.sku.id) {
|
|
console.log(this.sku);
|
|
console.log(this.sku.stock);
|
|
if (this.sku.stock < 1) {
|
|
uni.showToast({
|
|
title: '库存不够!'
|
|
});
|
|
return;
|
|
}
|
|
let params = {
|
|
goodsId: id,
|
|
skuId: this.sku.id
|
|
};
|
|
// data = await Api.apiCall('post', Api.order.addCart, params);
|
|
let dataJson = {};
|
|
|
|
dataJson.goodsId = this.goods.id;
|
|
|
|
dataJson.type = 1;
|
|
dataJson.skuId = this.sku.id;
|
|
let url = '/pages/order/createOrder?dataJson=' + JSON.stringify(dataJson);
|
|
|
|
uni.navigateTo({
|
|
url: url
|
|
});
|
|
} else {
|
|
if (this.goods.stock < 1) {
|
|
uni.showToast({
|
|
title: '库存不够!'
|
|
});
|
|
return;
|
|
}
|
|
let params = {
|
|
goodsId: id
|
|
};
|
|
// data = await Api.apiCall('post', Api.order.addCart, params);
|
|
let dataJson = {};
|
|
|
|
dataJson.goodsId = this.goods.id;
|
|
|
|
dataJson.type = 1;
|
|
|
|
let url = '/pages/order/createOrder?dataJson=' + JSON.stringify(dataJson);
|
|
|
|
uni.navigateTo({
|
|
url: url
|
|
});
|
|
}
|
|
},
|
|
async addCart(item) {
|
|
if (!this.hasLogin) {
|
|
let url = '/pages/public/login';
|
|
uni.navigateTo({
|
|
url
|
|
});
|
|
return false;
|
|
}
|
|
let userInfo = uni.getStorageSync('userInfo');
|
|
console.log(userInfo);
|
|
console.log(this.goods.storeId);
|
|
if (userInfo && userInfo.storeId && userInfo.storeId == this.goods.storeId) {
|
|
uni.showToast({
|
|
title: '不能购买自己店铺的商品!'
|
|
});
|
|
return;
|
|
}
|
|
let id = item.id;
|
|
let data;
|
|
|
|
if (this.sku && this.sku.id) {
|
|
if (this.sku.stock < 1) {
|
|
uni.showToast({
|
|
title: '库存不够!'
|
|
});
|
|
return;
|
|
}
|
|
let params = {
|
|
goodsId: id,
|
|
skuId: this.sku.id
|
|
};
|
|
data = await Api.apiCall('post', Api.order.addCart, params);
|
|
} else {
|
|
if (this.goods.stock < 1) {
|
|
uni.showToast({
|
|
title: '库存不够!'
|
|
});
|
|
return;
|
|
}
|
|
let params = {
|
|
goodsId: id
|
|
};
|
|
data = await Api.apiCall('post', Api.order.addCart, params);
|
|
}
|
|
console.log("data=========:" + data)
|
|
if (data) {
|
|
this.$api.msg('添加购物车成功!');
|
|
} else {
|
|
this.$api.msg('加入购物车错误');
|
|
}
|
|
},
|
|
stopPrevent() {}
|
|
}
|
|
};
|
|
</script>
|
|
|
|
<style lang="scss">
|
|
page {
|
|
background: $page-color-base;
|
|
padding-bottom: 160upx;
|
|
}
|
|
|
|
.icon-you {
|
|
font-size: $font-base + 2upx;
|
|
color: #888;
|
|
}
|
|
|
|
.carousel {
|
|
height: 722upx;
|
|
position: relative;
|
|
|
|
swiper {
|
|
height: 100%;
|
|
}
|
|
|
|
.image-wrapper {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
|
|
.swiper-item {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-content: center;
|
|
height: 750upx;
|
|
overflow: hidden;
|
|
|
|
image {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 标题简介 */
|
|
.introduce-section {
|
|
background: #fff;
|
|
padding: 20upx;
|
|
|
|
.title {
|
|
font-size: 32upx;
|
|
color: $font-color-dark;
|
|
height: 50upx;
|
|
line-height: 50upx;
|
|
}
|
|
|
|
.price-box {
|
|
display: flex;
|
|
align-items: baseline;
|
|
height: 64upx;
|
|
padding: 10upx 0;
|
|
font-size: 26upx;
|
|
color: $uni-color-primary;
|
|
}
|
|
|
|
.price {
|
|
font-size: $font-lg + 2upx;
|
|
}
|
|
|
|
.m-price {
|
|
margin: 0 12upx;
|
|
color: $font-color-light;
|
|
}
|
|
|
|
.coupon-tip {
|
|
align-items: center;
|
|
padding: 4upx 10upx;
|
|
background: $uni-color-primary;
|
|
font-size: $font-sm;
|
|
color: #fff;
|
|
border-radius: 6upx;
|
|
line-height: 1;
|
|
transform: translateY(-4upx);
|
|
}
|
|
|
|
.bot-row {
|
|
display: flex;
|
|
align-items: center;
|
|
height: 50upx;
|
|
font-size: $font-sm;
|
|
color: $font-color-light;
|
|
|
|
text {
|
|
flex: 1;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 分享 */
|
|
.share-section {
|
|
display: flex;
|
|
align-items: center;
|
|
color: $font-color-base;
|
|
background: linear-gradient(left, #fdf5f6, #fbebf6);
|
|
padding: 12upx 30upx;
|
|
|
|
.share-icon {
|
|
display: flex;
|
|
align-items: center;
|
|
width: 70upx;
|
|
height: 30upx;
|
|
line-height: 1;
|
|
border: 1px solid $uni-color-primary;
|
|
border-radius: 4upx;
|
|
position: relative;
|
|
overflow: hidden;
|
|
font-size: 22upx;
|
|
color: $uni-color-primary;
|
|
|
|
&:after {
|
|
content: '';
|
|
width: 50upx;
|
|
height: 50upx;
|
|
border-radius: 50%;
|
|
left: -20upx;
|
|
top: -12upx;
|
|
position: absolute;
|
|
background: $uni-color-primary;
|
|
}
|
|
}
|
|
|
|
.icon-xingxing {
|
|
position: relative;
|
|
z-index: 1;
|
|
font-size: 24upx;
|
|
margin-left: 2upx;
|
|
margin-right: 10upx;
|
|
color: #fff;
|
|
line-height: 1;
|
|
}
|
|
|
|
.tit {
|
|
font-size: $font-base;
|
|
margin-left: 10upx;
|
|
}
|
|
|
|
.icon-bangzhu1 {
|
|
padding: 10upx;
|
|
font-size: 30upx;
|
|
line-height: 1;
|
|
}
|
|
|
|
.share-btn {
|
|
flex: 1;
|
|
text-align: right;
|
|
font-size: $font-sm;
|
|
color: $uni-color-primary;
|
|
}
|
|
|
|
.icon-you {
|
|
font-size: $font-sm;
|
|
margin-left: 4upx;
|
|
color: $uni-color-primary;
|
|
}
|
|
}
|
|
|
|
.c-list {
|
|
font-size: $font-sm + 2upx;
|
|
color: $font-color-base;
|
|
background: #fff;
|
|
|
|
.c-row {
|
|
display: flex;
|
|
align-items: center;
|
|
padding: 20upx;
|
|
position: relative;
|
|
}
|
|
|
|
.tit {
|
|
width: 140upx;
|
|
}
|
|
|
|
.con {
|
|
flex: 1;
|
|
color: $font-color-dark;
|
|
|
|
.selected-text {
|
|
margin-right: 10upx;
|
|
}
|
|
}
|
|
|
|
.bz-list {
|
|
height: 40upx;
|
|
font-size: $font-sm + 2upx;
|
|
color: $font-color-dark;
|
|
|
|
text {
|
|
display: inline-block;
|
|
margin-right: 30upx;
|
|
}
|
|
}
|
|
|
|
.con-list {
|
|
flex: 1;
|
|
display: flex;
|
|
flex-direction: column;
|
|
color: $font-color-dark;
|
|
line-height: 40upx;
|
|
}
|
|
|
|
.red {
|
|
color: $uni-color-primary;
|
|
}
|
|
}
|
|
|
|
/* 评价 */
|
|
.eva-section {
|
|
display: flex;
|
|
flex-direction: column;
|
|
padding: 20upx;
|
|
background: #fff;
|
|
margin-top: 16upx;
|
|
|
|
.e-header {
|
|
display: flex;
|
|
align-items: center;
|
|
height: 70upx;
|
|
font-size: $font-sm + 2upx;
|
|
color: $font-color-light;
|
|
|
|
.tit {
|
|
font-size: $font-base + 2upx;
|
|
color: $font-color-dark;
|
|
margin-right: 4upx;
|
|
}
|
|
|
|
.tip {
|
|
flex: 1;
|
|
text-align: right;
|
|
}
|
|
|
|
.icon-you {
|
|
margin-left: 10upx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.eva-box {
|
|
display: flex;
|
|
padding: 20upx 0;
|
|
|
|
.portrait {
|
|
flex-shrink: 0;
|
|
width: 80upx;
|
|
height: 80upx;
|
|
border-radius: 100px;
|
|
}
|
|
|
|
.right {
|
|
flex: 1;
|
|
display: flex;
|
|
flex-direction: column;
|
|
font-size: $font-base;
|
|
color: $font-color-base;
|
|
padding-left: 26upx;
|
|
|
|
.con {
|
|
font-size: $font-base;
|
|
color: $font-color-dark;
|
|
padding: 20upx 0;
|
|
}
|
|
|
|
.bot {
|
|
display: flex;
|
|
justify-content: space-between;
|
|
font-size: $font-sm;
|
|
color: $font-color-light;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 详情 */
|
|
.detail-desc {
|
|
background: #fff;
|
|
margin-top: 16upx;
|
|
width: 100%;
|
|
|
|
.d-header {
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
height: 80upx;
|
|
font-size: $font-base + 2upx;
|
|
color: $font-color-dark;
|
|
position: relative;
|
|
|
|
text {
|
|
padding: 0 20upx;
|
|
background: #fff;
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
&:after {
|
|
position: absolute;
|
|
left: 50%;
|
|
top: 50%;
|
|
transform: translateX(-50%);
|
|
width: 300upx;
|
|
height: 0;
|
|
content: '';
|
|
border-bottom: 1px solid #ccc;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 规格选择弹窗 */
|
|
.attr-content {
|
|
padding: 10upx 30upx;
|
|
|
|
.a-t {
|
|
display: flex;
|
|
|
|
image {
|
|
width: 170upx;
|
|
height: 170upx;
|
|
flex-shrink: 0;
|
|
margin-top: -40upx;
|
|
border-radius: 8upx;
|
|
}
|
|
|
|
.right {
|
|
display: flex;
|
|
flex-direction: column;
|
|
padding-left: 24upx;
|
|
font-size: $font-sm + 2upx;
|
|
color: $font-color-base;
|
|
line-height: 42upx;
|
|
|
|
.price {
|
|
font-size: $font-lg;
|
|
color: $uni-color-primary;
|
|
margin-bottom: 10upx;
|
|
}
|
|
|
|
.selected-text {
|
|
margin-right: 10upx;
|
|
}
|
|
}
|
|
}
|
|
|
|
.attr-list {
|
|
display: flex;
|
|
flex-direction: column;
|
|
font-size: $font-base + 2upx;
|
|
color: $font-color-base;
|
|
padding-top: 30upx;
|
|
padding-left: 10upx;
|
|
}
|
|
|
|
.item-list {
|
|
padding: 20upx 0 0;
|
|
display: flex;
|
|
flex-wrap: wrap;
|
|
|
|
text {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
background: #eee;
|
|
margin-right: 20upx;
|
|
margin-bottom: 20upx;
|
|
border-radius: 100upx;
|
|
min-width: 60upx;
|
|
height: 60upx;
|
|
padding: 0 20upx;
|
|
font-size: $font-base;
|
|
color: $font-color-dark;
|
|
}
|
|
|
|
.selected {
|
|
background: #fbebee;
|
|
color: $uni-color-primary;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 弹出层 */
|
|
.popup {
|
|
position: fixed;
|
|
left: 0;
|
|
top: 0;
|
|
right: 0;
|
|
bottom: 0;
|
|
z-index: 99;
|
|
|
|
&.show {
|
|
display: block;
|
|
|
|
.mask {
|
|
animation: showPopup 0.2s linear both;
|
|
}
|
|
|
|
.layer {
|
|
animation: showLayer 0.2s linear both;
|
|
}
|
|
}
|
|
|
|
&.hide {
|
|
.mask {
|
|
animation: hidePopup 0.2s linear both;
|
|
}
|
|
|
|
.layer {
|
|
animation: hideLayer 0.2s linear both;
|
|
}
|
|
}
|
|
|
|
&.none {
|
|
display: none;
|
|
}
|
|
|
|
.mask {
|
|
position: fixed;
|
|
top: 0;
|
|
width: 100%;
|
|
height: 100%;
|
|
z-index: 1;
|
|
background-color: rgba(0, 0, 0, 0.4);
|
|
}
|
|
|
|
.layer {
|
|
position: fixed;
|
|
z-index: 99;
|
|
bottom: 0;
|
|
width: 100%;
|
|
min-height: 40vh;
|
|
border-radius: 10upx 10upx 0 0;
|
|
background-color: #fff;
|
|
|
|
.btn {
|
|
height: 66upx;
|
|
line-height: 66upx;
|
|
border-radius: 100upx;
|
|
background: $uni-color-primary;
|
|
font-size: $font-base + 2upx;
|
|
color: #fff;
|
|
margin: 30upx auto 20upx;
|
|
}
|
|
}
|
|
|
|
@keyframes showPopup {
|
|
0% {
|
|
opacity: 0;
|
|
}
|
|
|
|
100% {
|
|
opacity: 1;
|
|
}
|
|
}
|
|
|
|
@keyframes hidePopup {
|
|
0% {
|
|
opacity: 1;
|
|
}
|
|
|
|
100% {
|
|
opacity: 0;
|
|
}
|
|
}
|
|
|
|
@keyframes showLayer {
|
|
0% {
|
|
transform: translateY(120%);
|
|
}
|
|
|
|
100% {
|
|
transform: translateY(0%);
|
|
}
|
|
}
|
|
|
|
@keyframes hideLayer {
|
|
0% {
|
|
transform: translateY(0);
|
|
}
|
|
|
|
100% {
|
|
transform: translateY(120%);
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 底部操作菜单 */
|
|
.page-bottom {
|
|
position: fixed;
|
|
left: 30upx;
|
|
bottom: 30upx;
|
|
z-index: 95;
|
|
display: flex;
|
|
justify-content: center;
|
|
align-items: center;
|
|
width: 690upx;
|
|
height: 100upx;
|
|
background: rgba(255, 255, 255, 0.9);
|
|
box-shadow: 0 0 20upx 0 rgba(0, 0, 0, 0.5);
|
|
border-radius: 16upx;
|
|
|
|
.p-b-btn {
|
|
display: flex;
|
|
flex-direction: column;
|
|
align-items: center;
|
|
justify-content: center;
|
|
font-size: $font-sm;
|
|
color: $font-color-base;
|
|
width: 96upx;
|
|
height: 80upx;
|
|
|
|
.yticon {
|
|
font-size: 40upx;
|
|
line-height: 48upx;
|
|
color: $font-color-light;
|
|
}
|
|
|
|
&.active,
|
|
&.active .yticon {
|
|
color: $uni-color-primary;
|
|
}
|
|
|
|
.icon-fenxiang2 {
|
|
font-size: 42upx;
|
|
transform: translateY(-2upx);
|
|
}
|
|
|
|
.icon-shoucang {
|
|
font-size: 46upx;
|
|
}
|
|
}
|
|
|
|
.action-btn-group {
|
|
display: flex;
|
|
height: 76upx;
|
|
border-radius: 100px;
|
|
overflow: hidden;
|
|
box-shadow: 0 20upx 40upx -16upx #fa436a;
|
|
box-shadow: 1px 2px 5px rgba(219, 63, 96, 0.4);
|
|
background: linear-gradient(to right, #ffac30, #fa436a, #f56c6c);
|
|
margin-left: 20upx;
|
|
position: relative;
|
|
|
|
&:after {
|
|
content: '';
|
|
position: absolute;
|
|
top: 50%;
|
|
right: 50%;
|
|
transform: translateY(-50%);
|
|
height: 28upx;
|
|
width: 0;
|
|
border-right: 1px solid rgba(255, 255, 255, 0.5);
|
|
}
|
|
|
|
.action-btn {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
width: 180upx;
|
|
height: 100%;
|
|
font-size: $font-base;
|
|
padding: 0;
|
|
border-radius: 0;
|
|
background: transparent;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 优惠券面板 */
|
|
.mask {
|
|
display: flex;
|
|
align-items: flex-end;
|
|
position: fixed;
|
|
left: 0;
|
|
top: var(--window-top);
|
|
bottom: 0;
|
|
width: 100%;
|
|
background: rgba(0, 0, 0, 0);
|
|
z-index: 9995;
|
|
transition: 0.3s;
|
|
|
|
.mask-content {
|
|
width: 100%;
|
|
min-height: 30vh;
|
|
max-height: 70vh;
|
|
background: #f3f3f3;
|
|
transform: translateY(100%);
|
|
transition: 0.3s;
|
|
overflow-y: scroll;
|
|
}
|
|
|
|
&.none {
|
|
display: none;
|
|
}
|
|
|
|
&.show {
|
|
background: rgba(0, 0, 0, 0.4);
|
|
|
|
.mask-content {
|
|
transform: translateY(0);
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 优惠券列表 */
|
|
.coupon-item {
|
|
display: flex;
|
|
flex-direction: column;
|
|
margin: 20upx 24upx;
|
|
background: #fff;
|
|
|
|
.con {
|
|
display: flex;
|
|
align-items: center;
|
|
position: relative;
|
|
height: 120upx;
|
|
padding: 0 30upx;
|
|
|
|
&:after {
|
|
position: absolute;
|
|
left: 0;
|
|
bottom: 0;
|
|
content: '';
|
|
width: 100%;
|
|
height: 0;
|
|
border-bottom: 1px dashed #f3f3f3;
|
|
transform: scaleY(50%);
|
|
}
|
|
}
|
|
|
|
.left {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
flex: 1;
|
|
overflow: hidden;
|
|
height: 100upx;
|
|
}
|
|
|
|
.title {
|
|
font-size: 32upx;
|
|
color: $font-color-dark;
|
|
margin-bottom: 10upx;
|
|
}
|
|
|
|
.time {
|
|
font-size: 24upx;
|
|
color: $font-color-light;
|
|
}
|
|
|
|
.right {
|
|
display: flex;
|
|
flex-direction: column;
|
|
justify-content: center;
|
|
align-items: center;
|
|
font-size: 26upx;
|
|
color: $font-color-base;
|
|
height: 100upx;
|
|
}
|
|
|
|
.price {
|
|
font-size: 44upx;
|
|
color: $base-color;
|
|
|
|
&:before {
|
|
content: '¥';
|
|
font-size: 34upx;
|
|
}
|
|
}
|
|
|
|
.tips {
|
|
font-size: 24upx;
|
|
color: $font-color-light;
|
|
line-height: 60upx;
|
|
padding-left: 30upx;
|
|
}
|
|
|
|
.circle {
|
|
position: absolute;
|
|
left: -6upx;
|
|
bottom: -10upx;
|
|
z-index: 10;
|
|
width: 20upx;
|
|
height: 20upx;
|
|
background: #f3f3f3;
|
|
border-radius: 100px;
|
|
|
|
&.r {
|
|
left: auto;
|
|
right: -6upx;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* 分类推荐楼层 */
|
|
.hot-floor {
|
|
width: 100%;
|
|
overflow: hidden;
|
|
margin-bottom: 20upx;
|
|
|
|
.floor-img-box {
|
|
width: 100%;
|
|
height: 220upx;
|
|
position: relative;
|
|
display: flex;
|
|
|
|
&:after {
|
|
padding: 10 30upx;
|
|
content: '';
|
|
position: absolute;
|
|
width: 100%;
|
|
height: 100%;
|
|
background: linear-gradient(rgba(255, 255, 255, 0.06) 30%, #f8f8f8);
|
|
}
|
|
}
|
|
|
|
.name {
|
|
font-size: 30upx;
|
|
color: $font-color-base;
|
|
margin-left: 24upx;
|
|
}
|
|
|
|
.floor-img {
|
|
width: 100%;
|
|
height: 100%;
|
|
}
|
|
|
|
.floor-list {
|
|
white-space: nowrap;
|
|
padding: 20upx;
|
|
padding-right: 50upx;
|
|
border-radius: 6upx;
|
|
margin-top: -140upx;
|
|
margin-left: 30upx;
|
|
background: #fff;
|
|
box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.2);
|
|
position: relative;
|
|
z-index: 1;
|
|
}
|
|
|
|
.scoll-wrapper {
|
|
display: flex;
|
|
align-items: flex-start;
|
|
}
|
|
|
|
.floor-item {
|
|
width: 180upx;
|
|
margin-right: 20upx;
|
|
font-size: $font-sm + 2upx;
|
|
color: $font-color-dark;
|
|
line-height: 1.8;
|
|
|
|
image {
|
|
width: 100upx;
|
|
height: 180upx;
|
|
border-radius: 6upx;
|
|
}
|
|
|
|
.price {
|
|
color: $uni-color-primary;
|
|
}
|
|
}
|
|
|
|
.more {
|
|
display: flex;
|
|
align-items: center;
|
|
justify-content: center;
|
|
flex-direction: column;
|
|
flex-shrink: 0;
|
|
width: 180upx;
|
|
height: 180upx;
|
|
border-radius: 6upx;
|
|
background: #f3f3f3;
|
|
font-size: $font-base;
|
|
color: $font-color-light;
|
|
|
|
text:first-child {
|
|
margin-bottom: 4upx;
|
|
}
|
|
}
|
|
}
|
|
</style>
|
|
|