<template> <view :data-theme="theme"> <skeleton :show="showSkeleton" :isNodes="isNodes" ref="skeleton" loading="chiaroscuro" selector="skeleton" bgcolor="#FFF"></skeleton> <view class="product-con skeleton" :style="{visibility: showSkeleton ? 'hidden' : 'visible'}"> <view class='navbar' :class="opacity>0.6?'bgwhite':''"> <view class='navbarH' :style='"height:"+navH+"rpx;"'> <view class='navbarCon acea-row' :style="{ paddingRight: navbarRight + 'px' }"> <!-- #ifdef MP --> <view class="select_nav flex justify-center align-center" id="home" :style="{ top: homeTop + 'rpx' }"> <text class="iconfont icon-fanhui2 px-20" @tap="returns"></text> <text class="iconfont icon-gengduo5 px-20" @tap="showNav"></text> <text class="nav_line"></text> </view> <!-- #endif --> <!-- #ifdef H5 || APP-PLUS --> <view id="home" class="home acea-row row-center-wrapper iconfont icon-xiangzuo h5_back" :class="opacity>0.5?'on':''" :style="{ top: homeTop + 'rpx' }" v-if="returnShow" @tap="returns"> </view> <!-- #endif --> <navigator url="/pages/goods_search/index" class="input" hover-class="none" :style="{ top: homeTop + 'rpx' }"><text class="iconfont icon-xiazai5"></text> 搜索商品</navigator> <!-- #ifdef H5 || APP-PLUS --> <view class="right_select" :style="{ top: homeTop + 'rpx' }" @tap="showNav"> <text class="iconfont icon-gengduo2"></text> </view> <!-- #endif --> </view> </view> <view class="tab_nav" v-show="opacity > 0.6"> <view class="header flex justify-between align-center"> <view class="item" :class="navActive === index ? 'on' : ''" v-for="(item,index) in navList" :key='index' @tap="tap(index)"> {{ item }} </view> </view> </view> </view> <view class="dialog_nav" v-show="currentPage" :style="{ top: navH + 'rpx' }"> <view class="dialog_nav_item" :class="item.after" v-for="(item,index) in selectNavList" :key="index" @click="linkPage(item.url)"> <text class="iconfont" :class="item.icon"></text> <text class="pl-20">{{item.name}}</text> </view> </view> <view class="detail_container"> <scroll-view :scroll-top="scrollTop" scroll-y='true' scroll-with-animation="true" :style='"height:"+height+"px;"' @scroll="scroll"> <view id="past0"> <productConSwiper class="skeleton-rect" :imgUrls="sliderImage" :videoline="videoLink" @videoPause="videoPause"></productConSwiper> <view class="pad30"> <view class='wrapper mb30 borRadius14'> <view class='share acea-row row-between row-bottom'> <view class='x-money skeleton-rect flex align-baseline'>¥ <text class='num font-44'>{{attr.productSelect.price}}</text> <view class="flex pl-2" v-if="attr.productSelect.vipPrice && attr.productSelect.vipPrice > 0"> <image src="../../static/images/vip_badge.png" class="vip_icon"></image> <text class='vip_money skeleton-rect'>¥{{attr.productSelect.vipPrice}}</text> </view> </view> <view class='iconfont icon-fenxiang' @click="listenerActionSheet"></view> </view> <view class='introduce skeleton-rect'>{{productInfo.storeName}}</view> <view class='label acea-row row-between-wrapper'> <view class="skeleton-rect">原价:¥{{attr.productSelect.otPrice || 0}}</view> <view class="skeleton-rect"> 库存:{{attr.productSelect.stock || 0}}{{productInfo.unitName || ''}}</view> <view class="skeleton-rect"> 销量:{{Math.floor(productInfo.sales) + Math.floor(productInfo.ficti) || 0}}{{productInfo.unitName || ''}} </view> </view> <view v-if="defaultCoupon.length>0 && type=='normal'" class='coupon acea-row row-between-wrapper' @click='couponTap'> <view class='hide line1 acea-row skeleton-rect'>优惠券: <view class='activity'>满{{defaultCoupon[0].minPrice}}减{{defaultCoupon[0].money}} </view> </view> <view class='iconfont icon-jiantou'></view> </view> <view class="coupon acea-row row-between-wrapper" v-if="activityH5.length"> <view class="line1 acea-row"> <text class="activityName skeleton-rect">活 动:</text> <view v-for='(item,index) in activityH5' :key='index' @click="goActivity(item)" class="activityBox"> <view v-if="item.type === '1'" class="skeleton-rect" :class="index==0?'activity_pin':'' || index==1?'activity_miao':'' || index==2?'activity_kan':''"> <text class="iconfonts iconfont icon-miaosha1"></text> <text class="activity_title"> 参与秒杀</text> </view> <view class="skeleton-rect" :class="index==0?'activity_pin':'' || index==1?'activity_miao':'' || index==2?'activity_kan':''" v-if="item.type === '2'"> <text class="iconfonts iconfont icon-kanjia"></text> <text class="activity_title"> 参与砍价</text> </view> <view class="skeleton-rect" :class="index==0?'activity_pin':'' || index==1?'activity_miao':'' || index==2?'activity_kan':''" v-if="item.type === '3'"> <text class="iconfonts iconfont icon-pintuan"></text> <text class="activity_title"> 参与拼团</text> </view> </view> </view> </view> </view> <view class='attribute mb30 borRadius14' @click="selecAttr"> <view class="acea-row row-between-wrapper"> <view class="line1 skeleton-rect">{{attrTxt}}: <text class='atterTxt'>{{attrValue}}</text> </view> <view class='iconfont icon-jiantou'></view> </view> <view class="acea-row row-between-wrapper" style="margin-top:7px;padding-left:55px;" v-if="skuArr.length > 1"> <view class="flex"> <image :src="item.image" v-for="(item,index) in skuArr.slice(0,4)" :key="index" class="attrImg"></image> </view> <view class="switchTxt">共{{skuArr.length}}种规格可选</view> </view> </view> <view class='userEvaluation' id="past1"> <view class='title acea-row row-between-wrapper' :style="replyCount==0?'border-bottom-left-radius:14rpx;border-bottom-right-radius:14rpx;':''"> <view>用户评价<i>({{replyCount}})</i></view> <navigator class='praise' hover-class='none' :url='"/pages/users/goods_comment_list/index?productId="+id'> <i>好评</i> <text class='font_color px-12'>{{replyChance || 0}}%</text> <text class='iconfont icon-jiantou'></text> </navigator> </view> <block v-if="replyCount"> <userEvaluation :reply="reply"></userEvaluation> </block> </view> <!-- 优品推荐 --> <view class="superior borRadius14" if='good_list.length' id="past2"> <view class="title acea-row row-center-wrapper"> <image src="../../static/images/xzuo.png"></image> <view class="titleTxt">优品推荐</view> <image src="../../static/images/xyou.png"></image> </view> <view class="slider-banner banner"> <swiper indicator-dots="true" :autoplay="autoplay" :circular="circular" :interval="interval" :duration="duration" indicator-color="#999" :indicator-active-color="indicatorBg" :style="'height:'+clientHeight+'px'"> <swiper-item v-for="(item,indexw) in good_list" :key="indexw"> <view class="list acea-row row-middle" :id="'list'+indexw"> <view class="item" v-for="(val,indexn) in item.list" :key="indexn" @click="goDetail(val)"> <view class="pictrue"> <image :src="val.image"></image> <span class="pictrue_log pictrue_log_class" v-if="val.activityH5 && val.activityH5.type === '1'">秒杀</span> <span class="pictrue_log pictrue_log_class" v-if="val.activityH5 && val.activityH5.type === '2'">砍价</span> <span class="pictrue_log pictrue_log_class" v-if="val.activityH5 && val.activityH5.type === '3'">拼团</span> </view> <view class="name line1">{{val.storeName}}</view> <view class="money theme_price">¥{{val.price}}</view> </view> </view> </swiper-item> <!-- <view class="swiper-pagination" slot="pagination"></view> --> </swiper> </view> </view> </view> </view> <view class='product-intro' id="past3"> <view class='title'> <image src="../../static/images/xzuo.png"></image> <span class="sp">产品详情</span> <image src="../../static/images/xyou.png"></image> </view> <view class='conter'> <jyf-parser :html="description" ref="article" :tag-style="tagStyle"></jyf-parser> </view> </view> <view style='height:120rpx;'></view> </scroll-view> </view> <view class='footer acea-row row-between-wrapper'> <!-- #ifdef MP --> <button hover-class='none' class='item skeleton-rect' @click="onClickService" v-if="chatConfig.telephone_service_switch === '1'"> <view class='iconfont icon-kefu'></view> <view>客服</view> </button> <button open-type="contact" hover-class='none' class='item skeleton-rect' v-else> <view class='iconfont icon-kefu'></view> <view>客服</view> </button> <!-- #endif --> <!-- #ifndef MP --> <view class="item skeleton-rect" @click="onClickService"> <view class="iconfont icon-kefu"></view> <view>客服</view> </view> <!-- #endif --> <block v-if="type === 'normal'"> <view @click="setCollect" class='item skeleton-rect'> <view class='iconfont icon-shoucang1' v-if="userCollect"></view> <view class='iconfont icon-shoucang' v-else></view> <view>收藏</view> </view> <navigator open-type='switchTab' class="animated item skeleton-rect" :class="animated==true?'bounceIn':''" url='/pages/order_addcart/order_addcart' hover-class="none"> <view class=''> <!-- <text v-if="Math.floor(CartCount)>0" class='num bg_color'>{{CartCount}}</text> --> </view> <view></view> </navigator> <view class="bnt acea-row skeleton-rect" v-if="attr.productSelect.stock <= 0"> <form @submit="joinCart" report-submit="true"><button class="joinCart bnts" form-type="submit"></button></form> <form report-submit="true"><button class="bnts bg-color-hui" form-type="submit">已售罄</button> </form> </view> <view class="bnt acea-row skeleton-rect" v-else> <form @submit="joinCart" report-submit="true"><button class="joinCart bnts" form-type="submit"></button></form> <form @submit="goBuy" report-submit="true"><button class="buy bnts" form-type="submit">先享后付</button> </form> </view> </block> <view class="bnt bntVideo acea-row skeleton-rect" v-if="attr.productSelect.stock <= 0 && type === 'video'"> <form report-submit="true"><button class="bnts bg-color-hui" form-type="submit">已售罄</button> </form> </view> <view class="bnt bntVideo acea-row skeleton-rect" v-if="attr.productSelect.stock > 0 && type === 'video'"> <form @submit="goBuy" report-submit="true"><button class="buy bnts" form-type="submit">立即购买</button> </form> </view> </view> <shareRedPackets :sharePacket="sharePacket" @listenerActionSheet="listenerActionSheet" @showShare="showShare"></shareRedPackets> <!-- 组件 --> <productWindow :attr="attr" :isShow='1' :iSplus='1' @myevent="onMyEvent" @ChangeAttr="ChangeAttr" @ChangeCartNum="ChangeCartNum" @attrVal="attrVal" @iptCartNum="iptCartNum" id='product-window' @getImg="showImg" @installments="installments"> </productWindow> <couponListWindow :coupon='coupon' :typeNum="couponDeaultType[0].useType" @ChangCouponsClone="ChangCouponsClone" @ChangCoupons="ChangCoupons" @ChangCouponsUseState="ChangCouponsUseState" @tabCouponType="tabCouponType"></couponListWindow> <!-- 分享按钮 --> <view class="generate-posters" :class="posters ? 'on' : ''"> <view class="generateCon acea-row row-middle"> <!-- #ifndef MP --> <button class="item" hover-class="none" v-if="weixinStatus === true" @click="H5ShareBox = true"> <view class="pictrue"> <image src="../../static/images/weixin.png"></image> </view> <view class="">分享给好友</view> </button> <!-- #endif --> <!-- #ifdef MP --> <button class="item" open-type="share" hover-class="none"> <view class="pictrue"> <image src="../../static/images/weixin.png"></image> </view> <view class="">分享给好友</view> </button> <!-- #endif --> <!-- #ifdef APP-PLUS --> <view class="item" @click="appShare('WXSceneSession')"> <view class="iconfont icon-weixin3"></view> <view class="">微信好友</view> </view> <view class="item" @click="appShare('WXSenceTimeline')"> <view class="iconfont icon-pengyouquan"></view> <view class="">微信朋友圈</view> </view> <!-- #endif --> <!-- #ifdef H5 || MP --> <view class="item" @click="getpreviewImage"> <view class="pictrue"> <image src="../../static/images/changan.png"></image> </view> <view class="">预览发图</view> </view> <!-- #endif --> <!-- #ifdef MP --> <button class="item" hover-class="none" @click="savePosterPath"> <view class="pictrue"> <image src="../../static/images/haibao.png"></image> </view> <view class="">保存海报</view> </button> <!-- #endif --> </view> <view class="generateClose acea-row row-center-wrapper" @click="posterImageClose">取消</view> </view> <cus-previewImg ref="cusPreviewImg" :list="skuArr" @changeSwitch="changeSwitch" @shareFriend="listenerActionSheet" /> <view class="mask" v-if="posters" @click="closePosters"></view> <view class="mask" v-if="canvasStatus"></view> <view class="mask_transparent" v-if="currentPage" @touchmove="hideNav" @click="hideNav()"></view> <!-- 海报展示 --> <view class='poster-pop' v-if="canvasStatus"> <image :src='imagePath'></image> </view> <view class="canvas" v-else> <canvas style="width:750px;height:1190px;" canvas-id="firstCanvas"></canvas> <canvas canvas-id="qrcode" :style="{width: `${qrcodeSize}px`, height: `${qrcodeSize}px`}" /> </view> <!-- 发送给朋友图片 --> <view class="share-box" v-if="H5ShareBox"> <image src="/static/images/share-info.png" @click="H5ShareBox = false"></image> </view> </view> </view> </template> <script> import{ getfenqilist } from '@/api/api.js' import uQRCode from '@/js_sdk/Sansnn-uQRCode/uqrcode.js' import store from '@/store'; import { HTTP_H5_URL } from '@/config/app.js'; import { spread } from "@/api/user"; import { getProductDetail, collectAdd, collectDel, postCartAdd, getReplyList, getReplyConfig, getProductGood, getReplyProduct } from '@/api/store.js'; import { getCoupons, tokenIsExistApi } from '@/api/api.js'; import { getCartCounts } from '@/api/order.js'; import { toLogin } from '@/libs/login.js'; import { mapGetters } from "vuex"; import { imageBase64 } from "@/api/public"; import productConSwiper from '@/components/productConSwiper'; import couponListWindow from '@/components/couponListWindow'; import productWindow from '@/components/productWindow'; import userEvaluation from '@/components/userEvaluation'; import shareRedPackets from '@/components/shareRedPackets'; import cusPreviewImg from '@/components/cus-previewImg/cus-previewImg.vue' import { silenceBindingSpread,silenceBindingChannelId } from "@/utils"; import parser from "@/components/jyf-parser/jyf-parser"; import { computeUser } from "@/api/user.js"; // #ifdef MP import { base64src } from '@/utils/base64src.js' import { getQrcode } from '@/api/api.js'; // #endif let app = getApp(); import { setThemeColor } from '@/utils/setTheme.js' import { Debounce } from '@/utils/validate.js' export default { components: { productConSwiper, couponListWindow, productWindow, userEvaluation, shareRedPackets, cusPreviewImg, "jyf-parser": parser }, data() { let that = this; return { showSkeleton: true, //骨架屏显示隐藏 isNodes: 0, //控制什么时候开始抓取元素节点,只要数值改变就重新抓取 //属性是否打开 coupon: { coupon: false, type: 0, list: [], count: [] }, attrTxt: '请选择', //属性页面提示 attrValue: '', //已选属性 animated: false, //购物车动画 id: 0, //商品id replyCount: 0, //总评论数量 reply: [], //评论列表 productInfo: {}, //商品详情 productValue: [], //系统属性 couponList: [], //优惠券 cart_num: 1, //购买数量 isAuto: false, //没有授权的不会自动授权 isShowAuth: false, //是否隐藏授权 isOpen: false, //是否打开属性组件 actionSheetHidden: true, storeImage: '', //海报产品图 PromotionCode: '', //二维码图片 posterbackgd: '/static/images/posterbackgd.png', sharePacket: { isState: true, //默认不显示 touchstart: false }, //分销商详细 circular: false, autoplay: false, interval: 3000, duration: 500, clientHeight: "", systemStore: {}, //门店信息 good_list: [], replyChance: 0, CartCount: 0, isDown: true, posters: false, weixinStatus: false, attr: { cartAttr: false, productAttr: [], productSelect: {} }, description: '', navActive: 0, H5ShareBox: false, //公众号分享图片 activityH5: [], retunTop: true, //顶部返回 navH: "", navList: [], opacity: 0, scrollY: 0, topArr: [], toView: '', height: 0, heightArr: [], lock: false, scrollTop: 0, tagStyle: { img: 'width:100%;display:block;', table: 'width:100%', video: 'width:100%' }, sliderImage: [], videoLink: '', qrcodeSize: 600, canvasStatus: false, //是否显示海报 imagePath: '', //海报路径 imgTop: '', errT: '', homeTop: 20, navbarRight: 0, userCollect: false, returnShow: true, //判断顶部返回是否出现 type: "", //视频号普通商品类型 theme: app.globalData.theme, indicatorBg: '', shareStatus: true, skuArr: [], currentPage: false, selectSku: {}, selectNavList: [{ name: '首页', icon: 'icon-shouye8', url: '/pages/index/index', after: 'dialog_after' }, { name: '搜索', icon: 'icon-sousuo6', url: '/pages/goods_search/index', after: 'dialog_after' }, { name: '购物车', icon: 'icon-gouwuche7', url: '/pages/order_addcart/order_addcart', after: 'dialog_after' }, { name: '我的收藏', icon: 'icon-shoucang3', url: '/pages/users/user_goods_collection/index', after: 'dialog_after' }, { name: '个人中心', icon: 'icon-gerenzhongxin1', url: '/pages/user/index' }, ], chatConfig: { consumer_hotline: '', telephone_service_switch: '0' }, //客服配置 defaultCoupon: [], couponDeaultType: [{ useType: 1 }], //优惠券分页数据 where: { page: 1, limit: 999, productId: 0, type: 0 }, couponType: 0,//优惠券类型 类型,1-通用,2-商品,3-品类 fenqlist:[],//分期 }; }, computed: mapGetters(['isLogin', 'uid', 'chatUrl', 'productType']), watch: { productInfo: { handler: function() { this.$nextTick(() => {}); }, immediate: true } }, onShow() { //校验token是否有效,true为有效,false为无效 this.getTokenIsExist(); }, onLoad(options) { // console.log(JSON.stringify(options),"options.spread") alert("options.spread"+JSON.stringify(options)) //用户从分享卡片进入的场景下获取主题色配置 this.$set(this, 'theme', this.$Cache.get('theme')); //判断顶部返回是否出现 var pages = getCurrentPages(); this.returnShow = pages.length === 1 ? false : true; if (pages.length <= 1) { this.retunTop = false } //页面中需要计算的一些值 let that = this; uni.getSystemInfo({ success: function(res) { that.height = res.windowHeight //res.windowHeight:获取整个窗口高度为px,*2为rpx;98为头部占据的高度; // #ifndef APP-PLUS || H5 || MP-ALIPAY //that.navbarRight = res.windowWidth - uni.getMenuButtonBoundingClientRect().left; // #endif }, }); //获取浏览器中的参数,商品id video视频号商品,normal普通商品 if (!options.scene && !options.id) { this.showSkeleton = false; this.$util.Tips({ title: '缺少参数无法查看商品' }, { url: '/pages/index/index' }); return; } if (options.id) this.id = options.id; // 仅仅小程序扫码进入获取商品id,商品类型 if (options.scene) { let value = this.$util.getUrlParams(decodeURIComponent(options.scene)); this.id = value.id ? value.id : ''; this.type = value.type ? value.type : 'normal'; } if (options.type === 'video') { // #ifdef MP this.navH = 160; // #endif this.type = options.type } else { this.type = 'normal' this.navH = app.globalData.navHeight; } // 商品类型vuex存储 this.$store.commit("PRODUCT_TYPE", this.type); // 客服配置 this.$set(this, 'chatConfig', this.$Cache.getItem('chatConfig')); // #ifdef H5 computeUser(); // #endif if (options.spread) app.globalData.spread = options.spread; if (options.channelId) app.globalData.channelId = options.channelId; this.getGoodsDetails(); //商品详情 this.getCouponType(); //获取默认的 优惠券类型 this.getProductReplyList(); //评论列表 this.getProductReplyCount(); //评论条数 this.getGoods(); //优品推荐 //主题色颜色配置 this.indicatorBg = setThemeColor(); }, onReady() { this.isNodes++; this.$nextTick(function() { // #ifdef MP const menuButton = uni.getMenuButtonBoundingClientRect(); const query = uni.createSelectorQuery().in(this); query .select('#home') .boundingClientRect(data => { this.homeTop = menuButton.top * 2 + menuButton.height - data.height; }) .exec(); // #endif // #ifdef APP-PLUS this.homeTop = 60; // #endif }); }, /** * 用户点击右上角分享 */ // #ifdef MP onShareAppMessage: function(res) { let that = this; that.$set(that, 'actionSheetHidden', !that.actionSheetHidden); return { title: that.productInfo.storeName || '', imageUrl: that.productInfo.image || '', path: '/pages/goods_details/index?id=' + that.id + '&spread=' + that.uid, } }, // #endif onReachBottom() { this.getCouponList(this.couponType); }, // 滚动监听 onPageScroll(e) { // 传入scrollTop值并触发所有easy-loadimage组件下的滚动监听事件 uni.$emit('scroll'); }, methods: { // // 请求分期列表 // getfqList: function() { // let data = { // limit:15, // page:1, // uid:this.$store.getters.uid // } // getfenqilist(data).then(res => { // this.fenqlist = res.data.list // // localStorage.setItem('fqlist',JSON.stringify(this.fenqlist)) // }) // }, //校验token是否有效,true为有效,false为无效 getTokenIsExist() { this.$LoginAuth.getTokenIsExist().then(data => { if (data) { this.getCouponList(1); //优惠券列表 类型,1-通用,2-商品,3-品类 this.getCartCount(true); //购物车数量 //绑定关系 if (parseInt(app.globalData.spread) > 0) silenceBindingSpread(); if (parseInt(app.globalData.channelId) > 0) silenceBindingChannelId(); } }); }, // #ifdef APP-PLUS appShare(scene) { let that = this let routes = getCurrentPages(); // 获取当前打开过的页面路由数组 let curRoute = routes[routes.length - 1].$page.fullPath // 获取当前页面路由,也就是最后一个打开的页面路由 uni.share({ provider: "weixin", scene: scene, type: 0, href: `${HTTP_H5_URL}${curRoute}&spread=${that.uid}`, title: that.productInfo.storeName, summary: app.globalData.companyName, imageUrl: that.productInfo.image, success: function(res) { that.posters = false; }, fail: function(err) { uni.showToast({ title: '分享失败', icon: 'none', duration: 2000 }) that.posters = false; } }); }, // #endif onClickService() { if (this.chatConfig.telephone_service_switch === '1') { uni.makePhoneCall({ phoneNumber: this.chatConfig.consumer_hotline //仅为示例 }); } else { // #ifdef APP-PLUS uni.navigateTo({ url: '/pages/users/web_page/index?webUel=' + this.chatUrl + '&title=客服' }) // #endif // #ifndef APP-PLUS location.href = this.chatUrl; // #endif } }, goActivity: function(e) { let item = e; if (item.type === "1") { uni.navigateTo({ url: `/pages/activity/goods_seckill_details/index?id=${item.id}` }); } else if (item.type === "2") { uni.navigateTo({ url: `/pages/activity/goods_bargain_details/index?id=${item.id}&startBargainUid=${this.uid}` }); } else { uni.navigateTo({ url: `/pages/activity/goods_combination_details/index?id=${item.id}` }); } }, /** * 购物车手动填写 * */ iptCartNum: function(e) { this.$set(this.attr.productSelect, 'cart_num', e ? e : 1); }, // 后退 returns: function() { uni.navigateBack() }, showNav() { this.currentPage = !this.currentPage; }, tap: function(index) { var id = "past" + index; var index = index; var that = this; this.$set(this, 'toView', id); this.$set(this, 'navActive', index); this.$set(this, 'lock', true); this.$set(this, 'scrollTop', index > 0 ? that.topArr[index] - (app.globalData.navHeight / 2) : that .topArr[index]); }, scroll: function(e) { var that = this, scrollY = e.detail.scrollTop; var opacity = scrollY / 500; opacity = opacity > 1 ? 1 : opacity; that.$set(that, 'opacity', opacity); that.$set(that, 'scrollY', scrollY); if (that.lock) { that.$set(that, 'lock', false) return; } for (var i = 0; i < that.topArr.length; i++) { if (scrollY < that.topArr[i] - (app.globalData.navHeight / 2) + that.heightArr[i]) { that.$set(that, 'navActive', i) break } } that.$set(that.sharePacket, 'touchstart', true); //滑动屏幕时让分享气泡缩回 }, /* *去商品详情页 */ goDetail(item) { if (!item.activityH5) { uni.redirectTo({ url: '/pages/goods_details/index?id=' + item.id }) return } if (item.activityH5.length == 0) { uni.redirectTo({ url: '/pages/goods_details/index?id=' + item.id }) return } // 砍价 if (item.activityH5 && item.activityH5.type == 2) { uni.redirectTo({ url: `/pages/activity/goods_bargain_details/index?id=${item.activityH5.id}&bargain=${this.uid}` }) return } // 拼团 if (item.activityH5 && item.activityH5.type == 3) { uni.redirectTo({ url: `/pages/activity/goods_combination_details/index?id=${item.activityH5.id}` }) return } // 秒杀 if (item.activityH5 && item.activityH5.type == 1) { debugger uni.redirectTo({ url: `/pages/activity/goods_seckill_details/index?id=${item.activityH5.id}` }) return } }, ChangCouponsClone: function() { this.$set(this.coupon, 'coupon', false) }, /** * 购物车数量加和数量减 * */ ChangeCartNum: function(changeValue) { //changeValue:是否 加|减 //获取当前变动属性 let productSelect = this.productValue[this.attrValue]; //如果没有属性,赋值给商品默认库存 if (productSelect === undefined && !this.attr.productAttr.length) productSelect = this.attr.productSelect; //无属性值即库存为0;不存在加减; if (productSelect === undefined) return; let stock = productSelect.stock || 0; let num = this.attr.productSelect; if (changeValue) { num.cart_num++; if (num.cart_num > stock) { this.$set(this.attr.productSelect, "cart_num", stock); this.$set(this, "cart_num", stock); } } else { num.cart_num--; if (num.cart_num < 1) { this.$set(this.attr.productSelect, "cart_num", 1); this.$set(this, "cart_num", 1); } } }, attrVal(val) { this.$set(this.attr.productAttr[val.indexw], 'index', this.attr.productAttr[val.indexw].attrValues[val.indexn]); }, /** * 属性变动赋值 * */ ChangeAttr: function(res) { let productSelect = this.productValue[res]; this.$set(this, "selectSku", productSelect); if (productSelect) { this.$set(this.attr.productSelect, "image", productSelect.image); this.$set(this.attr.productSelect, "price", productSelect.price); this.$set(this.attr.productSelect, "stock", productSelect.stock); this.$set(this.attr.productSelect, "unique", productSelect.id); this.$set(this.attr.productSelect, "cart_num", 1); this.$set(this.attr.productSelect, "vipPrice", productSelect.vipPrice); this.$set(this.attr.productSelect, 'otPrice', productSelect.otPrice); this.$set(this, "attrValue", res); this.$set(this, "attrTxt", "已选择"); } else { this.$set(this.attr.productSelect, "image", this.productInfo.image); this.$set(this.attr.productSelect, "price", this.productInfo.price); this.$set(this.attr.productSelect, "stock", 0); this.$set(this.attr.productSelect, "unique", this.productInfo.id); this.$set(this.attr.productSelect, "cart_num", 1); this.$set(this.attr.productSelect, "vipPrice", this.productInfo.vipPrice); this.$set(this.attr.productSelect, 'otPrice', this.productInfo.otPrice); this.$set(this, "attrValue", ""); this.$set(this, "attrTxt", "请选择"); } }, /** * 领取完毕移除当前页面领取过的优惠券展示 */ ChangCoupons: function(e) { let coupon = e; let couponList = this.$util.ArrayRemove(this.couponList, 'id', coupon.id); this.$set(this, 'couponList', couponList); this.getCouponList(); }, setClientHeight: function() { let that = this; if (!that.good_list.length) return; let view = uni.createSelectorQuery().in(this).select("#list0"); view.fields({ size: true, }, data => { that.$set(that, 'clientHeight', data.height + 20) }).exec(); }, /** * 优品推荐 * */ getGoods() { getProductGood().then(res => { let good_list = res.data.list || []; let count = Math.ceil(good_list.length / 6); let goodArray = new Array(); for (let i = 0; i < count; i++) { let list = good_list.slice(i * 6, i * 6 + 6); if (list.length) goodArray.push({ list: list }); } this.$set(this, 'good_list', goodArray); let navList = ['商品', '评价', '详情']; if (goodArray.length) { navList.splice(2, 0, '推荐') } this.$set(this, 'navList', navList); this.$nextTick(() => { if (good_list.length) { // #ifndef APP-PLUS this.setClientHeight(); // #endif // #ifdef APP-PLUS setTimeout(() => { this.setClientHeight(); }, 1000) // #endif }; }) }); }, /** * 获取产品详情 * */ getGoodsDetails: function() { let that = this; getProductDetail(that.id, that.type).then(res => { let productInfo = res.data.productInfo; // 字符串数组转数组; let arrayImg = productInfo.sliderImage; let sliderImage = JSON.parse(arrayImg); if (that.getFileType(sliderImage[0]) == 'video') { //判断轮播图第一张是否是视频,如果是,就赋值给videoLink,并且将其在轮播图中删除 this.$set(this, 'videoLink', sliderImage[0]); sliderImage.splice(0, 1); } that.$set(that, 'sliderImage', sliderImage); that.$set(that, 'productInfo', productInfo); that.$set(that, 'description', productInfo.content); that.$set(that, 'userCollect', res.data.userCollect); that.$set(that.attr, 'productAttr', res.data.productAttr); that.$set(that, 'productValue', res.data.productValue); for (let key in res.data.productValue) { let obj = res.data.productValue[key]; that.skuArr.push(obj) } this.$set(this, "selectSku", that.skuArr[0]); that.$set(that.sharePacket, 'priceName', res.data.priceName); //that.$set(that.sharePacket, 'isState', Math.floor(res.data.priceName) != 0 ?false : true); that.$set(that.sharePacket, 'isState', (res.data.priceName != "0" && res.data.priceName !== null) ? false : true); that.$set(that, 'activityH5', res.data.activityAllH5 ? res.data.activityAllH5 : []); uni.setNavigationBarTitle({ title: productInfo.storeName.substring(0, 7) + "..." }) let productAttr = this.attr.productAttr.map(item => { return { attrName: item.attrName, attrValues: item.attrValues.split(','), id: item.id, isDel: item.isDel, productId: item.productId, type: item.type } }); this.$set(this.attr, 'productAttr', productAttr); if (that.isLogin) { that.getCartCount(); //#ifdef H5 that.make(that.uid); that.ShareInfo(); this.getImageBase64(this.productInfo.image); // #endif // #ifdef MP that.getQrcode(); // #endif }; setTimeout(function() { that.infoScroll(); }, 500); // #ifdef MP that.imgTop = res.data.productInfo.image // #endif // #ifndef H5 that.downloadFilestoreImage(); // #endif that.DefaultSelect(); this.showSkeleton = false setTimeout(() => { this.defaultCoupon = this.coupon.list; }, 1000) }).catch(err => { //状态异常返回上级页面 that.$util.Tips({ title: err.toString() }, { tab: 3, url: 1 }); this.showSkeleton = false }) }, //评论列表 getProductReplyList: function() { getReplyProduct(this.id).then(res => { this.reply = res.data.productReply ? [res.data.productReply] : []; }) }, //评论条数 getProductReplyCount: function() { let that = this; getReplyConfig(that.id).then(res => { that.$set(that, 'replyChance', res.data.replyChance * 100); that.$set(that, 'replyCount', res.data.sumCount); }); }, infoScroll: function() { var that = this, topArr = [], heightArr = []; for (var i = 0; i < that.navList.length; i++) { //productList //获取元素所在位置 var query = uni.createSelectorQuery().in(this); var idView = "#past" + i; // if (!that.data.good_list.length && i == 2) { // var idView = "#past" + 3; // } query.select(idView).boundingClientRect(); query.exec(function(res) { var top = res[0].top; var height = res[0].height; topArr.push(top); heightArr.push(height); that.$set(that, 'topArr', topArr); that.$set(that, 'heightArr', heightArr); }); }; }, /** * 默认选中属性 * */ DefaultSelect: function() { let productAttr = this.attr.productAttr; let value = []; //默认选中每种规格的第一个 productAttr.forEach(item => { value.push(item.attrValues[0]); }) for (let i = 0; i < value.length; i++) { this.$set(productAttr[i], "index", value[i]); } //sort();排序函数:数字-英文-汉字; let productSelect = this.productValue[value.join(",")]; if (productSelect && productAttr.length) { this.$set(this.attr.productSelect, "storeName", this.productInfo.storeName); this.$set(this.attr.productSelect, "image", productSelect.image); this.$set(this.attr.productSelect, "price", productSelect.price); this.$set(this.attr.productSelect, "stock", productSelect.stock); this.$set(this.attr.productSelect, "unique", productSelect.id); this.$set(this.attr.productSelect, "cart_num", 1); this.$set(this.attr.productSelect, "vipPrice", productSelect .vipPrice); //attr.productSelect.otPrice this.$set(this.attr.productSelect, 'otPrice', productSelect.otPrice); this.$set(this, "attrValue", value.join(",")); this.$set(this, "attrTxt", "已选择"); } else if (!productSelect && productAttr.length) { this.$set(this.attr.productSelect, "storeName", this.productInfo.storeName); this.$set(this.attr.productSelect, "image", this.productInfo.image); this.$set(this.attr.productSelect, "price", this.productInfo.price); this.$set(this.attr.productSelect, "stock", 0); this.$set(this.attr.productSelect, "unique", this.productInfo.id); this.$set(this.attr.productSelect, "cart_num", 1); this.$set(this.attr.productSelect, "vipPrice", this.productInfo.vipPrice); this.$set(this.attr.productSelect, 'otPrice', this.productInfo.otPrice); this.$set(this, "attrValue", ""); this.$set(this, "attrTxt", "请选择"); } else if (!productSelect && !productAttr.length) { this.$set(this.attr.productSelect, "storeName", this.productInfo.storeName); this.$set(this.attr.productSelect, "image", this.productInfo.image); this.$set(this.attr.productSelect, "price", this.productInfo.price); this.$set(this.attr.productSelect, "stock", this.productInfo.stock); this.$set(this.attr.productSelect, "unique", this.productInfo.id || ""); this.$set(this.attr.productSelect, "cart_num", 1); this.$set(this.attr.productSelect, "vipPrice", this.productInfo.vipPrice); this.$set(this.attr.productSelect, 'otPrice', this.productInfo.otPrice); this.$set(this, "attrValue", ""); this.$set(this, "attrTxt", "请选择"); } }, /** * 获取优惠券 * */ getCouponList(type) { let that = this; if (type != undefined || type != null) { that.where.type = type; } else { that.where.type = ""; } that.where.productId = that.id; if (that.loadend) return; if (that.loading) return; // if (isPage === true) that.$set(that, 'productList', []); that.loading = true; that.loadTitle = ''; getCoupons(that.where).then(res => { let list = res.data.list; let couponList = that.$util.SplitArray(list, that.coupon.list); let loadend = list.length < that.where.limit; that.loadend = loadend; that.loading = false; that.loadTitle = loadend ? '已全部加载' : '加载更多'; that.$set(that.coupon, 'list', couponList); that.$set(that.where, 'page', that.where.page + 1); }); }, async getCouponType() { //在onLoad只调用一次,获取默认的类型作为打开优惠券列表的参数,不会随着切换变化 let dataList = await getCoupons({ productId: this.id }); if (dataList.length) { this.couponDeaultType = dataList.data; this.$set(this.coupon, 'type', dataList); } }, //切换优惠券头部 tabCouponType(type) { this.loadend = false; this.loading = false; this.where.page = 1; this.where.limit = 999; this.$set(this.coupon, 'list', []); this.$set(this.coupon, 'type', type); this.couponType = type; //优惠券类型 this.getCouponList(type); }, ChangCouponsUseState(index) { let that = this; that.coupon.list[index].isUse = true; that.$set(that.coupon, 'list', that.coupon.list); that.$set(that.coupon, 'coupon', false); }, /** * * * 收藏商品 */ setCollect: function() { let that = this; if (this.isLogin === false) { toLogin(); } else { if (this.userCollect) { collectDel(this.productInfo.id).then(res => { that.$set(that, 'userCollect', !that.userCollect); }) } else { collectAdd(this.productInfo.id).then(res => { that.$set(that, 'userCollect', !that.userCollect); }) } } }, /** * 打开属性插件 */ selecAttr: function() { this.$set(this.attr, 'cartAttr', true); this.$set(this, 'isOpen', true); }, /** * 打开优惠券插件 */ couponTap: function() { let that = this; if (that.isLogin === false) { toLogin(); } else { // this.loadend = false; // this.loading = false; // this.$set(that.coupon, 'list', []); // //that.getCouponList(this.couponDeaultType[0].useType); //打开弹框默认请求商品券 that.$set(that.coupon, 'coupon', true); } }, onMyEvent: function() { this.$set(this.attr, 'cartAttr', false); this.$set(this, 'isOpen', false); }, /** * 打开属性加入购物车 * */ joinCart: function(e) { //是否登录 if (this.isLogin === false) { toLogin(); } else { this.goCat(1); } }, /* * 加入购物车 */ goCat: function(num) { let that = this, productSelect = that.productValue[this.attrValue]; //打开属性 if (that.attrValue) { //默认选中了属性,但是没有打开过属性弹窗还是自动打开让用户查看默认选中的属性 that.attr.cartAttr = !that.isOpen ? true : false; } else { if (that.isOpen) that.attr.cartAttr = true; else that.attr.cartAttr = !that.attr.cartAttr; } //只有关闭属性弹窗时进行加入购物车 if (that.attr.cartAttr === true && that.isOpen === false) return (that.isOpen = true); //如果有属性,没有选择,提示用户选择 if ( that.attr.productAttr.length && productSelect.stock === 0 && that.isOpen === true ) return that.$util.Tips({ title: "产品库存不足,请选择其它" }); if (num === 1) { let q = { productId: parseFloat(that.id), cartNum: parseFloat(that.attr.productSelect.cart_num), isNew: false, productAttrUnique: that.attr.productSelect !== undefined ? that.attr.productSelect.unique : that.productInfo.id }; postCartAdd(q).then(function(res) { that.isOpen = false; that.attr.cartAttr = false; that.$util.Tips({ title: "添加购物车成功", success: () => { that.getCartCount(true); } }); }) .catch(res => { that.isOpen = false; return that.$util.Tips({ title: res }); }); } else { this.getPreOrder(); } }, /** * 获取购物车数量 * @param boolean 是否展示购物车动画和重置属性 */ getCartCount: function(isAnima) { let that = this; const isLogin = that.isLogin; if (isLogin) { getCartCounts(true, 'total').then(res => { that.CartCount = res.data.count; //加入购物车后重置属性 if (isAnima) { that.animated = true; setTimeout(function() { that.animated = false; }, 500); } }); } }, /** * 立即购买 */ goBuy: Debounce(function(e) { if (this.isLogin === false) { toLogin(); } else { this.goCat(0); } }), /** * 预下单 */ getPreOrder: function() { this.$Order.getPreOrder(this.type === 'normal' ? 'buyNow' : 'video', [{ "attrValueId": parseFloat(this.attr.productSelect.unique), "productId": parseFloat(this.id), "productNum": parseFloat(this.attr.productSelect.cart_num) }]); // console.log(JSON.stringify(this.$Order)) this.isOpen = false; }, // 授权关闭 authColse: function(e) { this.isShowAuth = e }, /** * 分享打开 * */ listenerActionSheet: function() { if (this.isLogin === false) { toLogin(); } else { // #ifdef H5 if (this.$wechat.isWeixin() === true) { this.weixinStatus = true; } // #endif this.goPoster() this.posters = true; } }, closePosters: function() { this.posters = false; this.currentPage = false; }, //隐藏海报 posterImageClose: function() { this.canvasStatus = false this.posters = false; }, //替换安全域名 setDomain: function(url) { url = url ? url.toString() : ''; //本地调试打开,生产请注销 if (url.indexOf("https://") > -1) return url; else return url.replace('http://', 'https://'); }, //获取海报产品图(解决跨域问题,只适用于小程序) downloadFilestoreImage: function() { let that = this; uni.downloadFile({ url: that.setDomain(that.productInfo.image), success: function(res) { that.storeImage = res.tempFilePath; }, fail: function() { return that.$util.Tips({ title: '' }); that.storeImage = ''; }, }); }, // 小程序关闭分享弹窗; goFriend: function() { this.posters = false; }, // 小程序二维码 getQrcode() { let that = this; let data = { pid: that.uid, id: that.id, path: 'pages/goods_details/index' } getQrcode(data).then(res => { base64src(res.data.code, Date.now(), res => { that.PromotionCode = res; }); }).catch(err => { that.errT = err; }); }, // 生成二维码; make(uid) { let href = location.href.split('?')[0] + "?id=" + this.id + "&spread=" + this.uid; uQRCode.make({ canvasId: 'qrcode', text: href, size: this.qrcodeSize, margin: 10, success: res => { this.PromotionCode = res; }, complete: () => {}, fail: res => { this.$util.Tips({ title: '海报二维码生成失败!' }); } }) }, getImageBase64: function(images) { let that = this; imageBase64({ url: images }).then(res => { that.imgTop = res.data.code; }) }, /** * 获取产品分销二维码 * @param function successFn 下载完成回调 * */ downloadFilePromotionCode: function(successFn) { let that = this; getProductCode(that.id) .then(res => { uni.downloadFile({ url: that.setDomain(res.data.code), success: function(res) { that.$set(that, 'isDown', false); if (typeof successFn == 'function') successFn && successFn(res .tempFilePath); else that.$set(that, 'PromotionCode', res.tempFilePath); }, fail: function() { that.$set(that, 'isDown', false); that.$set(that, 'PromotionCode', ''); } }); }) .catch(err => { that.$set(that, 'isDown', false); that.$set(that, 'PromotionCode', ''); }); }, /** * 生成海报 */ goPoster: function() { let that = this; uni.showLoading({ title: '海报生成中', mask: true }); that.posters = false; let arrImagesUrl = ''; let arrImagesUrlTop = ''; if (!that.PromotionCode) { uni.hideLoading(); that.$util.Tips({ title: that.errT }); return } setTimeout(() => { if (!that.imgTop) { uni.hideLoading(); that.$util.Tips({ title: '无法生成商品海报!' }); return } }, 1000); uni.downloadFile({ url: that.imgTop, //仅为示例,并非真实的资源 success: (res) => { arrImagesUrlTop = res.tempFilePath; let arrImages = [that.posterbackgd, arrImagesUrlTop, that.PromotionCode]; let storeName = that.productInfo.storeName; let price = that.productInfo.price; setTimeout(() => { that.$util.PosterCanvas(arrImages, storeName, price, that.productInfo .otPrice, function(tempFilePath) { that.imagePath = tempFilePath; that.canvasStatus = true; uni.hideLoading(); }); }, 500); } }); }, // 图片预览; getpreviewImage: function() { if (this.imagePath) { let photoList = []; photoList.push(this.imagePath) uni.previewImage({ urls: photoList, current: this.imagePath }); } else { this.$util.Tips({ title: '您的海报尚未生成' }); } }, /* * 保存到手机相册 */ // #ifdef MP savePosterPath: function() { let that = this; uni.getSetting({ success(res) { if (!res.authSetting['scope.writePhotosAlbum']) { uni.authorize({ scope: 'scope.writePhotosAlbum', success() { uni.saveImageToPhotosAlbum({ filePath: that.imagePath, success: function(res) { that.posterImageClose(); that.$util.Tips({ title: '保存成功', icon: 'success' }); }, fail: function(res) { that.$util.Tips({ title: '保存失败' }); } }) } }) } else { uni.saveImageToPhotosAlbum({ filePath: that.imagePath, success: function(res) { that.posterImageClose(); that.$util.Tips({ title: '保存成功', icon: 'success' }); }, fail: function(res) { that.$util.Tips({ title: '保存失败' }); }, }) } } }) }, // #endif ShareInfo() { let data = this.productInfo; let href = location.href; if (this.$wechat.isWeixin()) { href = href.indexOf("?") === -1 ? href + "?spread=" + this.uid: href + "&spread=" + this.uid; let configAppMessage = { desc: app.globalData.companyName, title: data.storeName, link: href, imgUrl: data.image }; this.$wechat.wechatEvevt([ "updateAppMessageShareData", "updateTimelineShareData", "onMenuShareAppMessage", "onMenuShareTimeline" ], configAppMessage).then(res => { // console.log(res); }).catch(err => { console.log(err); }) } }, showShare(status) { let that = this; that.$set(that.sharePacket, 'touchstart', status); }, hideNav() { this.currentPage = false; }, //下拉导航页面跳转 linkPage(url) { if (url == '/pages/index/index' || url == '/pages/order_addcart/order_addcart' || url == '/pages/user/index') { uni.switchTab({ url }) } else { uni.navigateTo({ url }) } this.currentPage = false }, //点击sku图片打开轮播图 showImg(index) { this.$refs.cusPreviewImg.open(this.selectSku.suk) }, //滑动轮播图选择商品 changeSwitch(e) { let productSelect = this.skuArr[e]; this.$set(this, 'selectSku', productSelect); var skuList = productSelect.suk.split(','); skuList.forEach((i, index) => { this.$set(this.attr.productAttr[index], 'index', skuList[index]); }) if (productSelect) { this.$set(this.attr.productSelect, "image", productSelect.image); this.$set(this.attr.productSelect, "price", productSelect.price); this.$set(this.attr.productSelect, "stock", productSelect.stock); this.$set(this.attr.productSelect, "unique", productSelect.id); this.$set(this.attr.productSelect, "vipPrice", productSelect.vipPrice); this.$set(this, "attrTxt", "已选择"); this.$set(this, "attrValue", productSelect.suk) } }, getFileType(fileName) { // 后缀获取 let suffix = ''; // 获取类型结果 let result = ''; try { const flieArr = fileName.split('.'); suffix = flieArr[flieArr.length - 1]; } catch (err) { suffix = ''; } // fileName无后缀返回 false if (!suffix) { return false; } suffix = suffix.toLocaleLowerCase(); // 图片格式 const imglist = ['png', 'jpg', 'jpeg', 'bmp', 'gif']; // 进行图片匹配 result = imglist.find(item => item === suffix); if (result) { return 'image'; } // 匹配 视频 const videolist = ['mp4', 'm2v', 'mkv', 'rmvb', 'wmv', 'avi', 'flv', 'mov', 'm4v']; result = videolist.find(item => item === suffix); if (result) { return 'video'; } // 其他 文件类型 return 'other'; }, videoPause() { } }, } </script> <style scoped lang="scss"> .product-con { height: 100%; } .x-money { font-size: 28rpx; font-weight: 700; @include price_color(theme); } .bg-color-hui { background: #bbb !important; border-radius: 0 25px 25px 0; } .select_nav { width: 170rpx !important; height: 60rpx !important; border-radius: 33rpx; background: rgba(255, 255, 255, 0.3); border: 1px solid rgba(0, 0, 0, 0.07); color: #000; position: fixed; font-size: 18px; line-height: 62rpx; z-index: 1000; left: 14rpx; } .px-20 { padding: 0 20rpx 0; } .nav_line { content: ''; display: inline-block; width: 1px; height: 34rpx; background: #b3b3b3; position: absolute; left: 0; right: 0; margin: auto; } .bgwhite { background: #fff; } .input { display: flex; align-items: center; /* #ifdef MP */ width: 300rpx; /* #endif */ /* #ifndef MP */ width: 460rpx; /* #endif */ height: 58rpx; padding: 0 0 0 30rpx; border: 1px solid rgba(0, 0, 0, 0.07); border-radius: 33rpx; color: #666; font-size: 26rpx; position: fixed; left: 0; right: 0; margin: auto; background: rgba(255, 255, 255, 0.3); .iconfont { margin-right: 20rpx; font-size: 26rpx; color: #666666; } } .container_detail { /* #ifdef MP */ margin-top: 32rpx; /* #endif */ } .tab_nav { width: 100%; height: 48px; padding: 0 30rpx 0; } .right_select { width: 58rpx; height: 58rpx; background: rgba(255, 255, 255, 0.3); border: 1px solid rgba(0, 0, 0, 0.1); border-radius: 50%; position: fixed; right: 20rpx; text-align: center; line-height: 58rpx; } .dialog_nav { position: absolute; /* #ifdef MP */ left: 14rpx; /* #endif */ /* #ifdef H5 || APP-PLUS*/ right: 14rpx; /* #endif */ width: 240rpx; background: #FFFFFF; box-shadow: 0px 0px 16rpx rgba(0, 0, 0, 0.08); z-index: 310; border-radius: 14rpx; &::before { content: ''; width: 0; height: 0; position: absolute; /* #ifdef MP */ left: 0; right: 0; margin: auto; /* #endif */ /* #ifdef H5 || APP-PLUS */ right: 8px; /* #endif */ top: -9px; border-bottom: 10px solid #F5F5F5; border-left: 10px solid transparent; /*transparent 表示透明*/ border-right: 10px solid transparent; } } .dialog_nav_item { width: 100%; height: 84rpx; line-height: 84rpx; padding: 0 20rpx 0; box-sizing: border-box; border-bottom: #eee; font-size: 28rpx; color: #333; position: relative; .iconfont { font-size: 32rpx; } } .dialog_after { ::after { content: ''; position: absolute; width: 172rpx; height: 1px; background-color: #EEEEEE; bottom: 0; right: 0; } } .pl-20 { padding-left: 20rpx; } .activity { padding: 0 20rpx; @include coupons_border_color(theme); @include main_color(theme); font-size: 24rpx; line-height: 34rpx; position: relative; margin-left: 4rpx; } .product-con .wrapper .coupon .activity:before { content: ' '; position: absolute; width: 7rpx; height: 10rpx; border-radius: 0 7rpx 7rpx 0; @include coupons_border_color(theme); background-color: #fff !important; bottom: 50%; left: -3rpx; margin-bottom: -6rpx; // border-left-color: #fff ; @include white_left_border; } .product-con .wrapper .coupon .activity:after { content: ' '; position: absolute; width: 7rpx; height: 10rpx; border-radius: 7rpx 0 0 7rpx; @include coupons_border_color(theme); background-color: #fff; right: -3rpx; bottom: 50%; margin-bottom: -6rpx; // border-right-color: #fff; @include white_right_border; } .justify-center { justify-content: center; } .align-center { align-items: center; } .align-baseline { align-items: baseline; } .bg_color { @include main_bg_color(theme); } .vip_icon { width: 44rpx; height: 28rpx; } .pl-2 { padding-left: 20rpx; } .vip_money { background: #FFE7B9; border-radius: 4px; font-size: 22rpx; color: #333; line-height: 28rpx; text-align: center; padding: 0 6rpx; box-sizing: border-box; margin-left: -4rpx; } .theme_price { @include price_color(theme); } .activityName { line-height: 44rpx; } .userEvaluation { i { display: inline-block; } } .bntVideo { width: auto !important; .buy { border-radius: 50rpx !important; } } .attribute { .line1 { width: 600rpx; } } .chat-btn { background-color: antiquewhite !important; } .activity_pin { width: auto; height: 44rpx; line-height: 44rpx; // background: linear-gradient(90deg, rgba(233, 51, 35, 1) 0%, rgba(250, 101, 20, 1) 100%); @include linear-gradient(theme); opacity: 1; border-radius: 22rpx; padding: 0 15rpx; // margin-left: 19rpx; } .activity_miao { width: auto; height: 44rpx; line-height: 44rpx; padding: 0 15rpx; // background: linear-gradient(90deg, rgba(250, 102, 24, 1) 0%, rgba(254, 161, 15, 1) 100%); @include linear-gradient(theme); opacity: 1; border-radius: 22rpx; margin-left: 19rpx; } .iconfonts { color: #fff !important; font-size: 28rpx; } .activity_title { font-size: 24rpx; color: #fff; } .activity_kan { width: auto; height: 44rpx; line-height: 44rpx; padding: 0 15rpx; @include linear-gradient(theme); opacity: 1; border-radius: 22rpx; margin-left: 19rpx; } .mask { z-index: 300 !important; } .head-bar { background: #fff; } .generate-posters { width: 100%; height: 318rpx; background-color: #fff; position: fixed; left: 0; bottom: 0; z-index: 388; transform: translate3d(0, 100%, 0); transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9); border-top: 1rpx solid #eee; .generateCon { height: 220rpx; } .generateClose { height: 98rpx; font-size: 28rpx; color: #333333; border-top: 1px solid #eee; } .item { .pictrue { width: 96rpx; height: 96rpx; border-radius: 50%; margin: 0 auto 6rpx auto; image { width: 100%; height: 100%; border-radius: 50%; } } } } .generate-posters.on { transform: translate3d(0, 0, 0); } .generate-posters .item { flex: 1; text-align: center; font-size: 30rpx; } .generate-posters .item .iconfont { font-size: 80rpx; color: #5eae72; } .generate-posters .item .iconfont.icon-haibao { color: #5391f1; } .generate-posters .item .iconfont.icon-haowuquan1 { color: #ff954d; } .product-con .footer { padding: 0 40rpx 0 40rpx; position: fixed; bottom: 0; width: 100%; box-sizing: border-box; background-color: #fff; z-index: 277; border-top: 1rpx solid #f0f0f0; height: 100rpx; height: calc(120rpx+ constant(safe-area-inset-bottom)); ///兼容 IOS<11.2/ height: calc(120rpx + env(safe-area-inset-bottom)); ///兼容 IOS>11.2/ } .product-con .footer .item { font-size: 18rpx; color: #666; } .product-con .footer .item .iconfont { text-align: center; font-size: 40rpx; } .product-con .footer .item .iconfont.icon-shoucang1 { @include main_color(theme); } .product-con .footer .item .iconfont.icon-gouwuche1 { font-size: 40rpx; position: relative; } .product-con .footer .item .iconfont.icon-gouwuche1 .num { color: #fff; position: absolute; font-size: 18rpx; padding: 2rpx 8rpx 3rpx; border-radius: 200rpx; top: -10rpx; right: -10rpx; } .product-con .footer .bnt { width: 444rpx; height: 76rpx; } .product-con .footer .bnt .bnts { width: 444rpx; text-align: center; line-height: 76rpx; color: #fff; font-size: 28rpx; } .product-con .footer .bnt .joinCart { border-radius: 50rpx 0 0 50rpx; @include left_color(theme); } .product-con .footer .bnt .buy { // border-radius: 1rpx 50rpx 50rpx 0; @include main_bg_color(theme); } .product-con .store-info { margin-top: 20rpx; background-color: #fff; } .product-con .store-info .title { padding: 0 30rpx; font-size: 28rpx; color: #282828; height: 80rpx; line-height: 80rpx; border-bottom: 1px solid #f5f5f5; } .product-con .store-info .info { padding: 0 30rpx; height: 126rpx; } .product-con .store-info .info .picTxt { width: 615rpx; } .product-con .store-info .info .picTxt .pictrue { width: 76rpx; height: 76rpx; } .product-con .store-info .info .picTxt .pictrue image { width: 100%; height: 100%; border-radius: 6rpx; } .product-con .store-info .info .picTxt .text { width: 522rpx; } .product-con .store-info .info .picTxt .text .name { font-size: 30rpx; color: #282828; } .product-con .store-info .info .picTxt .text .address { font-size: 24rpx; color: #666; margin-top: 3rpx; } .product-con .store-info .info .picTxt .text .address .iconfont { color: #707070; font-size: 18rpx; margin-left: 10rpx; } .product-con .store-info .info .picTxt .text .address .addressTxt { max-width: 480rpx; } .product-con .store-info .info .iconfont { font-size: 40rpx; } .product-con .superior { background-color: #fff; margin-top: 30rpx; padding: 0 24rpx 30rpx 24rpx; } .product-con .superior .title { height: 98rpx; } .product-con .superior .title image { width: 20rpx; height: 20rpx; } .product-con .superior .title .titleTxt { margin: 0 10rpx; font-size: 30rpx; color: #333333; } .product-con .superior .slider-banner { width: 100%; margin: 0 auto; position: relative; } .product-con .superior .slider-banner swiper { height: 100%; width: 100%; } .product-con .superior .slider-banner swiper-item { height: 100%; } .product-con .superior .slider-banner .list { width: 100%; } .product-con .superior .slider-banner .list .item { width: 198rpx; margin: 0 22rpx 30rpx 0; font-size: 26rpx; } .product-con .superior .slider-banner .list .item:nth-of-type(3n) { margin-right: 0; } .product-con .superior .slider-banner .list .item .pictrue { position: relative; width: 100%; height: 198rpx; } .product-con .superior .slider-banner .list .item .pictrue image { width: 100%; height: 100%; border-radius: 6rpx; } .product-con .superior .slider-banner .list .item .name { color: #282828; margin-top: 12rpx; } .product-con .superior .slider-banner .swiper-pagination-bullet { background-color: #999; } .product-con .superior .slider-banner .swiper-pagination-bullet-active { background-color: $theme-color; } button { padding: 0; margin: 0; line-height: normal; background-color: #fff; } button::after { border: 0; } action-sheet-item { padding: 0; height: 240rpx; align-items: center; display: flex; } .contact { font-size: 16px; width: 50%; background-color: #fff; padding: 8rpx 0; border-radius: 0; margin: 0; line-height: 2; } .contact::after { border: none; } .action-sheet { font-size: 17px; line-height: 1.8; width: 50%; position: absolute; top: 0; right: 0; padding: 25rpx 0; } .canvas { position: fixed; z-index: -5; opacity: 0; } .poster-pop { position: fixed; width: 450rpx; height: 714rpx; top: 50%; left: 50%; transform: translateX(-50%); margin-top: -432rpx; z-index: 399; } .poster-pop image { width: 100%; height: 100%; display: block; } .poster-pop .close { width: 46rpx; height: 75rpx; position: fixed; right: 0; top: -73rpx; display: block; } .poster-pop .save-poster { background-color: #df2d0a; font-size: :22rpx; color: #fff; text-align: center; height: 76rpx; line-height: 76rpx; width: 100%; } .poster-pop .keep { color: #fff; text-align: center; font-size: 25rpx; margin-top: 10rpx; } .mask { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background-color: rgba(0, 0, 0, 0.6); } .pro-wrapper .iconn { background-image: url(''); width: 100rpx; height: 100rpx; background-repeat: no-repeat; background-size: 100% 100%; margin: 0 auto; } .pro-wrapper .iconn.iconn1 { background-image: url(''); } .pictrue_log { width: 80upx; height: 40upx; border-radius: 10upx 0 12upx 0; line-height: 40upx; font-size: 24upx; } .pictrue_log_class { z-index: 3; background: -webkit-gradient(linear, left top, right top, from(rgba(246, 122, 56, 1)), to(rgba(241, 27, 9, 1))); background: linear-gradient(90deg, rgba(246, 122, 56, 1) 0%, rgba(241, 27, 9, 1) 100%); opacity: 1; position: absolute; top: 0; left: 0; color: #fff; text-align: center; } .tab_nav .header { width: 100%; height: 96rpx; padding: 0 30rpx 0; font-size: 30rpx; color: #050505; background-color: #fff; } .icon-xiangzuo { /* #ifdef H5 */ top: 20rpx !important; /* #endif */ } .navbar .header .item { position: relative; margin: 0 25rpx; } .navbar .header .item.on:before { position: absolute; width: 60rpx; height: 5rpx; background-repeat: no-repeat; content: ""; @include linear-gradient(theme); bottom: -10rpx; left: 50%; margin-left: -28rpx; } .navbar { position: fixed; // background-color: #fff; top: 0; left: 0; z-index: 99; width: 100%; } .navbar .navbarH { position: relative; } .navbar .navbarH .navbarCon { position: absolute; bottom: 0; height: 100rpx; width: 100%; } .h5_back { color: #000; position: fixed; left: 20rpx; font-size: 32rpx; text-align: center; width: 58rpx; height: 58rpx; background: rgba(255, 255, 255, 0.3); border: 1px solid rgba(0, 0, 0, 0.1); border-radius: 50%; } .share-box { z-index: 1000; position: fixed; left: 0; top: 0; width: 100%; height: 100%; image { width: 100%; height: 100%; } } .mask_transparent { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: transparent; z-index: 300; } .px-12 { padding-left: 12rpx; padding-right: 12rpx; } .font-44 { font-size: 44rpx; } .font_color { @include main_color(theme); } .attrImg { width: 66rpx; height: 66rpx; border-radius: 6rpx; display: block; margin-right: 14rpx; } .switchTxt { height: 60rpx; flex: 1; line-height: 60rpx; box-sizing: border-box; background: #EEEEEE; padding-right: 0 24rpx 0; border-radius: 8rpx; text-align: center; } </style>