weipengfei c281a77a02 更新
2024-03-15 17:01:27 +08:00

1946 lines
51 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<view :class="bgTabVal==2?'fullsize noRepeat':bgTabVal==1?'repeat ysize':'noRepeat ysize'"
:style="'background-color:'+bgColor+';background-image: url('+bgPic+');min-height:'+windowHeight+'px;'"
id="home">
<skeleton :show="showSkeleton" :isNodes="isNodes" ref="skeleton" loading="chiaroscuro" selector="skeleton"
bgcolor="transparent"></skeleton>
<view v-if="!errorNetwork"
:style="{visibility: showSkeleton ? 'hidden' : 'visible', pointerEvents: preview ? 'none' : 'auto'}">
<view class="page-index skeleton" :class="{ bgf: navIndex > 0 }">
<block>
<!-- #ifdef H5 -->
<homeComb v-if="smallPage" class="home-comb" :isScale="isScale" :isMenu="isMenu"
:dataConfig="homeCombData" :userInfo="userInfo" :isFixed="isFixed" :isScrolled="isScrolled"
@changeDiy="changeDiy"></homeComb>
<!-- <card></card> -->
<view v-for="(item, index) in styleConfig" :key="index">
<block
v-if="item.name != 'headerSerch' && item.name != 'tabNav' && item.name != 'shopList' && item.name != 'homeComb' && item.name != 'hotRanking' && item.name != 'pageFoot'">
<component :is="item.name" :index="index" :isFixed="isFixed" :dataConfig="item"
:tempArr="tempArr" :userInfo="userInfo" :tabTitle="navTop" :navIndex="navIndex"
@changeTab="changeTab" @detail="goDetail" v-show="navIndex == 0"></component>
</block>
<block v-if="item.name == 'headerSerch'">
<headerSerch :dataConfig="item" :tempArr="tempArr" :userInfo="userInfo" :tabTitle="navTop"
@changeTab="changeTab" @detail="goDetail"></headerSerch>
</block>
<block v-if="item.name == 'shopList' && hide_mer_status != 1 && navIndex == 0">
<shopList :dataConfig="item"></shopList>
</block>
<block v-if="item.name == 'tabNav'">
<tabNav :isFixed="isFixed" :dataConfig="item" :tempArr="tempArr" :userInfo="userInfo"
:tabTitle="navTop" @changeTab="changeTab" @detail="goDetail"></tabNav>
</block>
<block v-if="item.name == 'homeComb' && !smallPage">
<homeComb :isMenu="isMenu" :dataConfig="item" :isFixed="isFixed" :isScrolled="isScrolled"
:userInfo="userInfo" @changeDiy="changeDiy"></homeComb>
</block>
<block v-if="item.name == 'hotRanking' && hot_ranking_switch != 0 && navIndex == 0">
<hotRanking :dataConfig="item"></hotRanking>
</block>
</view>
<!-- #endif -->
<!-- #ifdef MP || APP-PLUS -->
<homeComb class="home-comb" v-if="smallPage" :isScale="isScale" :isMenu="isMenu"
:dataConfig="homeCombData" :isFixed="isFixed" :isScrolled="isScrolled" :userInfo="userInfo"
@changeDiy="changeDiy" @bindHeight="bindHeighta"></homeComb>
<!-- <card></card> -->
<block v-for="(item, index) in styleConfig" :key="index">
<view v-show="navIndex == 0">
<homeComb v-if="item.name == 'homeComb' && !smallPage" :isMenu="isMenu" :dataConfig="item"
:isFixed="isFixed" :isScrolled="isScrolled" :userInfo="userInfo" @changeDiy="changeDiy"
@bindHeight="bindHeighta"></homeComb>
<activeParty v-if="item.name == 'activeParty'" :dataConfig="item"></activeParty>
<bargain v-if="item.name == 'bargain'" :dataConfig="item"></bargain>
<blankPage v-if="item.name == 'blankPage'" :dataConfig="item"></blankPage>
<combination v-if="item.name == 'combination'" :dataConfig="item"></combination>
<topic v-if="item.name == 'topic'" :dataConfig="item"></topic>
<coupon v-if="item.name == 'coupon'" :dataConfig="item"></coupon>
<customerService v-if="item.name == 'customerService'" :dataConfig="item"></customerService>
<goodList v-if="item.name == 'goodList'" :dataConfig="item" @detail="goDetail"></goodList>
<guide v-if="item.name == 'guide'" :dataConfig="item"></guide>
<liveBroadcast v-if="item.name == 'liveBroadcast'" :dataConfig="item"></liveBroadcast>
<menus :class="isMenu ? 'transform-view' : ''" v-if="item.name == 'menus'"
:dataConfig="item"></menus>
<news v-if="item.name == 'news'" :dataConfig="item"></news>
<presellList v-if="item.name == 'presellList'" :dataConfig="item"></presellList>
<plantList v-if="item.name == 'plantList'" :dataConfig="item"></plantList>
<hotRanking v-if="item.name == 'hotRanking' && hot_ranking_switch != 0" :dataConfig="item">
</hotRanking>
<promotionList v-if="item.name == 'promotionList'" :dataConfig="item" @changeTab="changeTab"
:tempArr="tempArr" @detail="goDetail"></promotionList>
<richText v-if="item.name == 'richText'" :dataConfig="item"></richText>
<seckill v-if="item.name == 'seckill'" :dataConfig="item"></seckill>
<swiperBg v-if="item.name == 'swiperBg'" :dataConfig="item"></swiperBg>
<pictureCube v-if="item.name == 'pictureCube'" :dataConfig="item"></pictureCube>
<titles v-if="item.name == 'titles'" :dataConfig="item"></titles>
<shopList v-if="item.name == 'shopList' && hide_mer_status != 1" :dataConfig="item">
</shopList>
</view>
<headerSerch v-if="item.name == 'headerSerch'" :dataConfig="item" :userInfo="userInfo">
</headerSerch>
<tabNav v-if="item.name == 'tabNav'" :dataConfig="item" class="tabNav" :tabTitle="navTop"
@bindHeight="bindHeighta" @changeTab="changeTab" :isFixed="isFixed"></tabNav>
</block>
<!-- #endif -->
<view class="main" v-show="navIndex == 0">
<!-- 首页推荐 -->
<view v-if="recommend_switch == 1" class="index-product-wrapper">
<!-- 首发新品 -->
<recommend ref="recommendRef" :hostProduct="hostProduct" @changeRecommedTab="changeRecommedTab" showTab :indexP="true" :isLogin="isLogin"></recommend>
<view class="loadingicon acea-row row-center-wrapper" v-if="hostProduct.length > 0 || hotLoading">
<text class="loading iconfont icon-jiazai" :hidden="hotLoading == false"></text>
{{ hotTitle }}
</view>
</view>
</view>
<view v-show="navIndex == 0" class="loadingicon acea-row row-center-wrapper"
v-if="tempArr.length && styleConfig[styleConfig.length - 1].name == 'promotionList'">
<text class="loading iconfont icon-jiazai" :hidden="loading == false"></text>
{{ loadTitle }}
</view>
</block>
<!-- 分类页 -->
<view class="productList" v-if="navIndex > 0">
<view class="sort acea-row" v-if="sortList.length>0" :style="{ marginTop: sortMarTop + 'px' }">
<navigator hover-class="none" v-if="index < 9"
:url="'/pages/columnGoods/goods_list/index?id=' + item.store_category_id + '&title=' + item.cate_name"
class="item" v-for="(item, index) in sortList" :key="item.store_category_id">
<view class="pictrue cate_pictrue">
<easy-loadimage :image-src="item.pic"></easy-loadimage>
<view v-if="item.border_pic" :style="{ backgroundImage: `url(${item.border_pic})` }"
class="border-picture"></view>
</view>
<view class="text">{{ item.cate_name }}</view>
</navigator>
<view class="item" @click="bindMore" v-if="sortList.length >= 9">
<view class="pictrues acea-row row-center-wrapper"><text
class="iconfont icon-gengduo1"></text></view>
<view class="text" style="margin-top: 22rpx;">更多</view>
</view>
</view>
<block v-if="sortProduct.length > 0">
<view class="list acea-row row-between-wrapper">
<navigator @tap="goDetails(item)" class="item" v-for="(item, index) in sortProduct"
:key="item.product_id">
<view class="pictrue">
<easy-loadimage :image-src="item.image"></easy-loadimage>
<view v-if="item.border_pic" :style="{ backgroundImage: `url(${item.border_pic})` }"
class="border-picture"></view>
</view>
<view class="text">
<view class="name line1">
<text class="name_text line2">{{ item.store_name }}</text>
</view>
<view class="acea-row row-middle">
<view class="money font-color-red">
<text class="num">{{ item.price }}</text>
</view>
</view>
<view class="item_tags acea-row">
<text v-if="item.merchant.type_name && item.product_type == 0"
class="font-bg-red">{{ item.merchant.type_name }}</text>
<text v-else-if="item.merchant.is_trader && item.product_type == 0"
class="font-bg-red">自营</text>
<text v-if="item.product_type != 0"
:class="'font_bg-red type' + item.product_type">
{{ item.product_type == 1 ? '秒杀' : item.product_type == 2 ? '预售' : item.product_type == 3 ? '助力' : item.product_type == 4 ? '拼团' : '' }}
</text>
<text class="tags_item ticket" v-if="item.issetCoupon">领券</text>
<text class="tags_item delivery" v-if="item.delivery_free == 1">包邮</text>
</view>
</view>
</navigator>
<view class="loadingicon acea-row row-center-wrapper"
v-if="sortProduct.length > 0 || sortProductLoading">
<text class="loading iconfont icon-jiazai" :hidden="loading == false"></text>
{{ loadTitle }}
</view>
</view>
</block>
<block v-if="sortProduct.length == 0">
<view class="noCommodity">
<view class="pictrue" style="margin: 0 auto;">
<image :src="`${domain}/static/images/noCart.png`"></image>
<view>暂无商品,去看点什么吧</view>
</view>
<recommend :hostProduct="hostProduct"></recommend>
</view>
</block>
</view>
<!-- #ifdef H5 -->
<a v-if="beian_sn" href="https://beian.miit.gov.cn/#/Integrated/index"
class="copyRight">{{beian_sn}}</a>
<!-- #endif -->
<!-- #ifndef H5 -->
<view v-if="beian_sn" class="copyRight">{{beian_sn}}</view>
<!-- #endif -->
</view>
</view>
<view v-else>
<view class="error-network">
<image :src="`${domain}/static/images/error-network.png`"></image>
<view class="title">网络连接断开</view>
<view class="con">
<view class="label">请检查情况:</view>
<view class="item">· 在设置中是否已开启网络权限</view>
<view class="item">· 当前是否处于弱网环境</view>
<view class="item">· 版本是否过低,升级试试吧</view>
</view>
<view class="btn" @click="reconnect">重新连接</view>
</view>
</view>
<!-- #ifdef APP-PLUS -->
<view class="privacy-wrapper" v-if="privacyStatus">
<view class="privacy-box">
<view class="title">用户协议与隐私政策</view>
<view class="content">
请务必审慎阅读、充分理解“用户协议 与 隐私政策”各条款,包括但不限于:为了 向你提供即时通讯、内容分享等服务,我 们需要收集你的设备信息、操作日志等个
人信息。你可以在“设置”中查看、变更、 删除个人信息并管理你的授权。
<br />
你可以阅读
<navigator url="/pages/users/user_about/index?from=sys_user_agree">《用户协议》</navigator>与<navigator
url="/pages/users/user_about/index?from=sys_userr_privacy">《隐私政策》</navigator>
了解 详细信息。如你同意,请点击“我同意”开始接受我们的服务。
</view>
<view class="btn-box">
<view class="btn-item" @click="confirmApp">我同意</view>
<view class="btn" @click="closeModel">随便逛逛</view>
</view>
</view>
</view>
<!-- #endif -->
<!-- 发送给朋友图片 -->
<view class="share-box" v-if="isIntegral">
<!-- #ifndef H5 -->
<image :src="`${domain}/static/images/share-info.png`" @click="closeShare"></image>
<!-- #endif -->
<!-- #ifdef H5 -->
<image :src="`${domain}/static/images/share-info-wechat.png`" @click="closeShare"></image>
<!-- #endif -->
</view>
<!-- 优惠券弹窗 -->
<view class="coupon_popups" v-if="showCoupon">
<view class="bg"></view>
<view class="con" :style="{ 'background-image': `url(${domain}/static/diy/couponWindow${keyColor}.png)` }">
<scroll-view scroll-y="true">
<view v-for="(item, index) in couponArray" class="item">
<view class="left">
<view class="price">¥ <text>{{item.coupon_price}}</text></view>
<view class="max_price" v-if="item.use_min_price > 0">满{{item.use_min_price}}可用</view>
<view class="max_price" v-else>无门槛</view>
</view>
<view class="right">
<view class="time line1" v-if="item.coupon_type">有效期{{item.use_start_time}} -
{{item.use_end_time}}
</view>
<text class="coupon_type">{{couponTypeMsg[item.type] || '店铺券'}}</text>
<navigator :url="'/pages/columnGoods/goods_coupon_list/index?coupon_id='+item.coupon_id"
class='bnt1 b-color' hover-class="none"><text
class="title titleSize">{{item.title}}</text>
<view class="title titleColor">
有效期:{{item.use_start_time}}-{{item.use_end_time}}
</view>
</navigator>
</view>
</view>
</scroll-view>
<view class="text">优惠券已放入您的账户中,点击“优惠券”去使用</view>
<view class='iconfont icon-guanbi3' @click="showCoupon = false"></view>
</view>
</view>
<!-- #ifndef H5 -->
<passwordPopup></passwordPopup>
<!-- #endif -->
<!--自定义底部tab栏-->
<customTab :newData="newData" :activeRouter="activeRouter"></customTab>
<view v-if="overflow" class="overflow-mask" @touchmove.stop.prevent="() => {}"></view>
</view>
</template>
<script>
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2023 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
var statusBarHeight = uni.getSystemInfoSync().statusBarHeight + 'px';
let app = getApp();
import {
getUserInfo
} from '@/api/user.js';
import {
getDiy,
getPageDiy,
getIndexData,
getAppVersion,
getCateData
} from '@/api/api.js';
import {
getNavigation
} from '@/api/public.js';
import {
getStorage
} from '@/libs/uniApi.js';
// #ifdef MP-WEIXIN
import {
getTemlIds
} from '@/api/api.js';
import {
SUBSCRIBE_MESSAGE,
TIPS_KEY
} from '@/config/cache';
// #endif
import {
getShare
} from '@/api/public.js';
import {
goShopDetail
} from '@/libs/order.js';
import {
toLogin
} from '@/libs/login.js';
import {
mapGetters
} from 'vuex';
import {
getProductslist,
getProductHot,
storeCategory
} from '@/api/store.js';
import {
initiateAssistApi
} from '@/api/activity.js';
import {
setVisit,
spread
} from '@/api/user.js';
import recommend from '@/components/recommend';
import card from './component/card';
// #ifndef H5
import passwordPopup from '@/components/passwordPopup';
// #endif
// #ifdef H5
import mConfig from './component/index.js';
// #endif
import customTab from '@/components/customTab';
// #ifdef MP || APP-PLUS
import activeParty from './component/activeParty';
import headerSerch from './component/headerSerch';
import homeComb from './component/homeComb';
import coupon from './component/coupon';
import bargain from './component/bargain';
import blankPage from './component/blankPage';
import combination from './component/combination';
import customerService from './component/customerService';
import goodList from './component/goodList';
import guide from './component/guide';
import liveBroadcast from './component/liveBroadcast';
import menus from './component/menus';
import news from './component/news';
import topic from './component/topic';
import presellList from './component/presellList';
import plantList from './component/plantList';
import pictureCube from './component/pictureCube'
import shopList from './component/shopList';
import richText from './component/richText';
import seckill from './component/seckill';
import swiperBg from './component/swiperBg';
import tabNav from './component/tabNav';
import titles from './component/titles';
import hotRanking from "./component/hotRanking.vue";
// #endif
import {
silenceBindingSpread,
configMap,
isWeixin
} from '@/utils/index';
import history from '@/mixins/history';
import shareScence from '@/libs/spread';
import easyLoadimage from '@/components/easy-loadimage/easy-loadimage.vue';
import {
getNewPeopleCouponLst
} from '@/api/activity.js'
import {
HTTP_REQUEST_URL
} from '@/config/app';
export default {
computed: configMap({
hide_mer_status: 0,
recommend_switch: 0,
beian_sn: '',
share_title: '',
share_pic: '',
site_name: '',
hot_ranking_switch: 0,
navigation: {}
},
mapGetters(['isLogin', 'uid', 'keyColor'])),
mixins: [history],
components: {
easyLoadimage,
recommend,
card,
customTab,
// #ifndef H5
passwordPopup,
// #endif
// #ifdef H5
...mConfig,
// #endif
// #ifdef MP || APP-PLUS
activeParty,
headerSerch,
homeComb,
bargain,
coupon,
blankPage,
combination,
customerService,
goodList,
guide,
liveBroadcast,
menus,
news,
topic,
presellList,
plantList,
pictureCube,
shopList,
richText,
seckill,
swiperBg,
tabNav,
titles,
hotRanking
// #endif
},
data() {
return {
domain: HTTP_REQUEST_URL,
couponTypeMsg: {
10: '通用券',
11: '品类券',
12: '跨店券'
},
styleConfig: [],
showSkeleton: true, //骨架屏显示隐藏
isNodes: 0, //控制什么时候开始抓取元素节点,只要数值改变就重新抓取
privacyStatus: false,
errorNetwork: false,
userInfo: {},
loading: false,
statusBarHeight: statusBarHeight,
navIndex: 0,
navTop: [],
subscribe: false,
followUrl: '',
followHid: true,
followCode: false,
sortList: [],
window: false,
navH: '',
couponList: [],
marTop: 0,
loadend: false,
loading: false,
loadTitle: '加载更多',
sortProduct: [],
where: {
pid: 0,
page: 1,
limit: 6
},
is_switch: true,
hostProduct: [],
hotPage: 1,
hotLimit: 30,
hotScroll: true,
hotLoading: false,
hotTitle: '加载更多',
// #ifdef MP || APP-PLUS
isFixed: false,
// #endif
// #ifdef H5
isFixed: false,
// #endif
isScrolled: false,
scrolled: false,
tempArr: [], //精品推荐临时数组
d: '',
h: '',
m: '',
s: '',
sum_h: '',
sortMarTop: 0,
globalDatas: {},
// #ifdef MP || APP-PLUS
mpHeight: 108,
// #endif
// #ifndef MP || APP-PLUS
mpHeight: 0,
// #endif
currSpid: '',
_options: {},
isIntegral: false,
appUpdate: {},
sortMpTop: 0,
bgColor: '',
bgPic: '',
bgTabVal: '',
windowHeight: 0,
domHeight: 0,
isHeaderSerch: false,
showCoupon: false,
couponArray: [],
smallPage: false,
isMenu: false,
isScale: false,
homeCombData: {},
footerStatus: false,
newData: {},
activeRouter: '',
overflow: false,
diyId: 0,
preview: false,
isSupport: true
};
},
/**
* 用户点击右上角分享
*/
// #ifdef MP
onShareAppMessage: function() {
let that = this;
wx.showShareMenu({
withShareTicket: true,
menus: ['shareAppMessage', 'shareTimeline']
});
return {
title: that.share_title,
imageUrl: "",
path: '/pages/index/index?spid=' + that.uid
};
},
onShareTimeline: function() {
let that = this;
return {
title: that.share_title,
query: {
spid: that.uid
},
imageUrl: ''
};
},
// #endif
onLoad(options) {
let that = this
this._options = options;
this.diyId = options.diyId || 0;
this.preview = options.time ? true : false;
// #ifdef APP-PLUS
that.appVersionConfig(); //APP版本检测
// #endif
that.$nextTick(function() {
uni.getSystemInfo({
success: function(res) {
that.windowHeight = res.windowHeight;
}
});
})
that.pageLoad(options);
},
created(options) {
let routes = getCurrentPages(); // 获取当前打开过的页面路由数组
let curRoute = routes[routes.length - 1].route //获取当前页面路由
this.activeRouter = '/' + curRoute
},
onShow() {
let that = this
that.isIntegral = uni.getStorageSync('isIntegral')
// #ifdef APP-PLUS
if (that.appUpdate.openUpgrade == '1') {
that.alertAppUpdate();
}
// #endif
that.getNav()
that.loadCoupon()
that.$nextTick(function() {
const query = uni.createSelectorQuery();
query.select('#home').boundingClientRect(); //获取当前元素距离顶部的距离
query.exec(res => {
that.isScrolled = res[0].top <= -60
})
})
},
onHide() {
uni.setStorageSync('isIntegral', false)
},
onReady() {
},
watch: {
globalDatas(nVal, oVal) {
// #ifdef H5
this.ShareInfo(nVal);
// #endif
},
},
onPullDownRefresh() {
this.overflow = true;
this.reconnect();
// #ifdef APP-PLUS
setTimeout(() => {
uni.reLaunch({
url: "/pages/index/index"
});
}, 50)
// #endif
},
methods: {
loadCoupon() {
if (!this.showCoupon && !uni.getStorageSync('show_coupon') && uni.getStorageSync('is_new_user')) {
getNewPeopleCouponLst().then(res => {
this.couponArray = res.data;
setTimeout(() => {
this.showCoupon = this.couponArray.length > 0;
uni.setStorageSync('show_coupon', '1')
}, 1500);
})
}
},
pageLoad(options) {
let that = this;
if (options.spid) {
that.currSpid = options.spid;
app.globalData.spid = options.spid;
} else if (getStorage('spid')) {
that.currSpid = getStorage('spid');
app.globalData.spid = getStorage('spid');
}
// #ifdef APP-PLUS
try {
let val = uni.getStorageSync('privacyStatus') || true;
if (!val) {
this.privacyStatus = true;
}
} catch (e) {}
this.snycNetWork();
// #endif
// #ifdef MP
if (options.scene) {
let value = that.$util.getUrlParams(decodeURIComponent(options.scene));
if (value.id) options.id = value.id;
//记录推广人uid
if (value.spid) {
that.currSpid = value.spid;
app.globalData.spid = value.spid;
} else if (getStorage('spid')) {
that.currSpid = getStorage('spid');
app.globalData.spid = getStorage('spid');
}
}
// #endif
shareScence(that.currSpid, that.isLogin);
this.isLogin && silenceBindingSpread();
this.reloadData();
Promise.all([
this.diyData(0),
]);
if (this.isLogin) {
this.getUserInfo();
}
},
closeShare() {
uni.setStorageSync('isIntegral', false);
this.isIntegral = uni.getStorageSync('isIntegral');
},
bindHeighta(data) {
// #ifdef APP-PLUS
this.sortMpTop = data.top + data.height;
// #endif
},
// 重新链接
reconnect() {
uni.getNetworkType({
success: res => {
this.errorNetwork = res.networkType === 'none';
if (!this.errorNetwork) {
this.pageLoad(this._options);
} else {
// uni.stopPullDownRefresh();
that.overflow = false;
}
}
});
},
getNav() {
getNavigation().then(res => {
this.newData = res.data
if (this.newData.status && this.newData.status.status) {
uni.hideTabBar()
} else {
uni.showTabBar()
}
})
},
// #ifdef APP-PLUS
snycNetWork() {
uni.getNetworkType({
success: res => {
this.errorNetwork = res.networkType === 'none';
}
});
},
// 同意隐私协议
confirmApp() {
uni.setStorageSync('privacyStatus', true);
this.privacyStatus = false;
},
// 关闭 Model
closeModel() {
this.privacyStatus = false;
},
// #endif
// 对象转数组
objToArr(data) {
let obj = Object.keys(data).sort();
let m = obj.map(key => data[key]);
return m;
},
goRouter(item) {
var pages = getCurrentPages();
var page = (pages[pages.length - 1]).$page.fullPath;
if (item.link == page) return
uni.switchTab({
url: item.link,
fail(err) {
uni.redirectTo({
url: item.link
})
}
})
},
diyData(id) {
let that = this;
let parmas = {
id: id,
did: that.diyId,
version: '221'
}
that.styleConfig = []
that.smallPage = false;
getDiy(parmas).then(res => {
setTimeout(() => {
that.isNodes++;
}, 0);
that.errorNetwork = false
let data = res.data;
uni.setNavigationBarTitle({
title: data.title
});
if (data.is_bg_color) {
that.bgColor = data.color_picker
}
if (data.is_bg_pic) {
that.bgPic = data.bg_pic
that.bgTabVal = data.bg_tab_val
} else {
that.bgPic = ""
}
that.styleConfig = that.objToArr(data.value);
that.styleConfig.forEach((item, index, arr) => {
item.did = data.id
if (item.name == 'headerSerch' || item.name == 'homeComb') {
that.isHeaderSerch = true
if (item.name == 'homeComb') {
that.$set(that, 'homeCombData', item);
uni.setStorageSync('swiperImgList', item.swiperConfig.list);
that.smallPage = true;
}
}
if (item.name == 'pageFoot') {
if (item.status && item.status.status) {
this.newData = item
setTimeout((e) => {
that.$set(that, 'footerStatus', true);
}, 50)
}
uni.setStorageSync('FOOTER_BAR', item.status && item.status.status ? true :
false)
item.menuList.map((path, index) => {
if (path.link === '/pages/order_addcart/order_addcart') {
uni.setStorageSync('FOOTER_ADDCART', index)
}
})
arr.splice(index, 1);
}
if (item.name == 'menus') {
that.isMenu = true;
}
if (that.recommend_switch == 1) that.loadGoods();
uni.pageScrollTo({
scrollTop: 0,
})
that.overflow = false;
uni.stopPullDownRefresh();
});
}).catch(err => {
uni.showToast({
title: err,
icon: 'none'
})
uni.stopPullDownRefresh();
});
},
changeDiy(id) {
let that = this;
if (id) {
that.styleConfig = []
getPageDiy({
id: id,
version: '221'
}).then(res => {
let data = res.data
uni.setNavigationBarTitle({
title: data.title
});
that.isScale = true
if (data.is_bg_color) {
that.bgColor = data.color_picker
}
if (data.is_bg_pic) {
that.bgPic = data.bg_pic
that.bgTabVal = data.bg_tab_val
} else {
that.bgPic = ""
}
that.styleConfig = that.objToArr(data.value);
that.styleConfig.forEach((item, index, arr) => {
item.did = data.id
if (item.name == 'headerSerch' || item.name == 'homeComb' || item.name ==
'tabNav') {
that.styleConfig.splice(index, 1);
}
if (item.name == 'menus') {
that.isMenu = true;
}
});
that.isHeaderSerch = true
that.isScale = true
uni.pageScrollTo({
scrollTop: 0,
})
uni.stopPullDownRefresh();
}).catch(err => {
that.styleConfig = []
uni.stopPullDownRefresh();
uni.showToast({
title: err,
icon: 'none'
})
});
} else {
that.diyData(0)
that.isScale = false
}
},
// #ifdef APP-PLUS
appVersionConfig() {
var that = this;
//app升级
// 获取本地应用资源版本号
getAppVersion().then(res => {
that.$set(that.appUpdate, 'androidAddress', res.data.androidAddress);
that.$set(that.appUpdate, 'appVersion', res.data.appVersion);
that.$set(that.appUpdate, 'iosAddress', res.data.iosAddress);
that.$set(that.appUpdate, 'openUpgrade', res.data.openUpgrade);
plus.runtime.getProperty(plus.runtime.appid, function(inf) {
let nowVersion = (inf.version).split('.').join('');
let appVersion = (res.data.appVersion).split('.').join('');
that.$set(that.appUpdate, 'alert', appVersion > nowVersion);
that.alertAppUpdate();
});
})
},
alertAppUpdate() {
if (this.appUpdate.alert) {
uni.getSystemInfo({
success: (res) => {
uni.showModal({
title: '更新提示',
content: '发现新版本,是否前去下载?',
showCancel: this.appUpdate.openUpgrade != '1',
cancelColor: '#eeeeee',
confirmColor: '#FF0000',
success: (response) => {
if (response.confirm) {
switch (res.platform) {
case "android":
plus.runtime.openURL(this
.appUpdate
.androidAddress);
break;
case "ios":
plus.runtime.openURL(encodeURI(
this.appUpdate
.iosAddress));
break;
}
}
}
});
}
})
}
},
// #endif
// 分类页更多
bindMore() {
try {
uni.setStorageSync('storeIndex', this.navTop[this.navIndex].pid);
uni.switchTab({
url: '/pages/goods_cate/goods_cate'
});
} catch (e) {}
},
goDetails(item) {
goShopDetail(item, this.uid).then(res => {
if (this.isLogin) {
initiateAssistApi(item.activity_id)
.then(res => {
let id = res.data.product_assist_set_id;
uni.hideLoading();
uni.navigateTo({
url: '/pages/activity/assist_detail/index?id=' + id
});
})
.catch(err => {
uni.showToast({
title: err,
icon: 'none'
});
});
} else {
toLogin()
}
});
},
/**
* 获取个人用户信息
*/
getUserInfo: function() {
let that = this;
getUserInfo().then(res => {
that.userInfo = res.data;
});
},
// 记录会员访问
setVisit() {
setVisit({
url: '/pages/index/index'
}).then(res => {
console.log(res);
});
},
// 导航分类切换
changeTab(e) {
let self = this;
if (this.navIndex == e.index) return;
this.navIndex = e.index;
if (e.index > 0) {
storeCategory({
pid: e.pid
}).then(res => {
this.sortList = res.data.length > 9 ? res.data.splice(0, 9) : res.data;
if (this.sortList.length > 0) {
this.where.pid = e.pid;
this.where.page = 1;
this.loadend = false;
this.loading = false;
this.sortProduct = [];
this.get_product_list();
uni.pageScrollTo({
scrollTop: 0,
})
}
});
self.sortMarTop = 10;
}
},
//分类产品
get_product_list: function() {
let that = this;
if (that.loading || that.loadend) return;
that.loading = true;
that.loadTitle = '';
getProductslist(that.where)
.then(res => {
let list = res.data.list;
let productList = that.$util.SplitArray(list, that.sortProduct);
let loadend = list.length < that.where.limit;
that.loadend = loadend;
that.loading = false;
that.loadTitle = loadend ? '已全部加载' : '加载更多';
that.$set(that, 'sortProduct', productList);
that.$set(that.where, 'page', that.where.page + 1);
})
.catch(err => {
that.loading = false;
that.loadTitle = '加载更多';
});
},
/**
* 点击组件选项卡
*/
changeRecommedTab(e){
this.hotPage = 1;
this.hotScroll = true;
this.$set(this, 'hostProduct', []);
this.loadGoods(e);
},
loadGoods(e=1){
if(e==1) return this.get_host_product();
if(e==2) return this.get_host_home({
mer_type: 1
});
if(e==3) return this.get_host_home({
mer_type: 2
});
if(e==4) return this.get_host_home({
mer_type: 3
});
},
/**
* 获取我的推荐
*/
get_host_product: function() {
let that = this;
let num = that.hotLimit;
if (!that.hotScroll) return;
if (that.hotLoading) return;
that.hotLoading = true;
that.hotTitle = '加载中';
getProductHot(that.hotPage, that.hotLimit).then(res => {
let list = res.data.list;
let productList = that.$util.SplitArray(list, that.hostProduct);
let hotScroll = list.length <= num && list.length != 0;
that.hotScroll = hotScroll;
that.hotLoading = false;
that.hotTitle = !hotScroll ? '已全部加载' : '加载更多';
that.$set(that, 'hostProduct', productList);
that.$set(that, 'hotPage', that.hotPage + 1);
});
},
/**
* 获取里海云仓, 云市场, 名优特产
*/
get_host_home: function(query={}) {
let that = this;
let num = that.hotLimit;
if (!that.hotScroll) return;
if (that.hotLoading) return;
that.hotLoading = true;
that.hotTitle = '加载中';
query.page = that.hotPage;
query.limit = that.hotLimit;
getProductslist({
...query
}).then(res => {
let list = res.data.list;
let productList = that.$util.SplitArray(list, that.hostProduct);
let hotScroll = list.length <= num && list.length != 0;
that.hotScroll = hotScroll;
that.hotLoading = false;
that.hotTitle = !hotScroll ? '已全部加载' : '加载更多';
that.$set(that, 'hostProduct', productList);
that.$set(that, 'hotPage', that.hotPage + 1);
});
},
getCateData() {
getCateData().then(res => {
res.data.unshift({
cate_name: '首页'
});
this.$set(this, 'navTop', res.data);
});
},
reloadData() {
setTimeout(() => {
this.showSkeleton = false
}, 500)
},
// 首发新品详情
goDetail(item) {
if (item.activity && item.activity.type === '2' && !this.isLogin) {
// #ifdef H5
uni.showModal({
title: '提示',
content: '您未登录,请登录!',
success: function(res) {
if (res.confirm) {
uni.navigateTo({
url: '/pages/users/login/index'
});
} else if (res.cancel) {}
}
});
// #endif
// #ifdef MP
toLogin()
// #endif
return;
} else {
goShopDetail(item, this.uid).then(res => {
if (this.isLogin) {
initiateAssistApi(item.activity_id)
.then(res => {
let id = res.data.product_assist_set_id;
uni.hideLoading();
uni.navigateTo({
url: '/pages/activity/assist_detail/index?id=' + id
});
})
.catch(err => {
uni.showToast({
title: err,
icon: 'none'
});
});
} else {
toLogin()
}
});
}
},
//#ifdef H5
ShareInfo(datas) {
let data = this.storeInfo;
let href = location.href;
if (this.$wechat.isWeixin()) {
if (this.isLogin) {
href = href.indexOf('?') === -1 ? href + '?spid=' + this.uid : href + '&spid=' + this.uid;
} else {
href = href;
}
let configAppMessage = {
desc: datas.share_info,
title: datas.share_title,
link: href,
imgUrl: datas.share_pic
};
this.$wechat
.wechatEvevt(['updateAppMessageShareData', 'updateTimelineShareData', 'onMenuShareAppMessage',
'onMenuShareTimeline'
], configAppMessage)
.then(res => {})
.catch(err => {
console.log(err);
});
}
},
//#endif
},
mounted() {
let query = uni.createSelectorQuery().in(this);
query.select("#home").boundingClientRect();
query.exec(res => {
this.domHeight = res[0].height;
})
},
// 滚动到底部
onReachBottom() {
if (this.recommend_switch == 1 && this.navIndex == 0) {
// 首页加载更多
this.loadGoods(this.$refs.recommendRef.currTabs || 1);
} else if (this.navIndex == 1) {
// 分类栏目加载更多
if (this.sortProduct.length > 0) {
this.get_product_list();
}
}
},
// 滚动监听
onPageScroll(e) {
this.isFixed = e.scrollTop > 40;
if (this.isHeaderSerch) {
let isScroll = false
isScroll = e.scrollTop > 50
this.isScrolled = isScroll;
} else {
this.isScrolled = false
}
// 传入scrollTop值并触发所有easy-loadimage组件下的滚动监听事件
uni.$emit('scroll');
}
};
</script>
<style>
</style>
<style lang="scss" scoped>
.bnt1 {
color: red;
}
.overflow-mask {
position: fixed;
top: 0;
left: 0;
z-index: 1001;
width: 100%;
height: 100vh;
background: transparent;
transition: all .5s;
}
page {
display: flex;
flex-direction: column;
}
/deep/ .home-comb .my-main {
left: 0;
position: fixed;
top: 0;
width: 100%;
z-index: 30;
}
.main {
padding: 0 20rpx;
}
.colum0 {
white-space: nowrap;
display: flex;
}
.ysize {
background-size: 100%;
}
.fullsize {
background-size: 100% 100%;
}
.repeat {
background-repeat: repeat;
}
.noRepeat {
background-repeat: no-repeat;
}
.privacy-wrapper {
z-index: 999;
position: fixed;
left: 0;
top: 0;
bottom: 0;
right: 0;
width: 100%;
height: 100%;
background: #7f7f7f;
.privacy-box {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
width: 560rpx;
padding: 50rpx 45rpx 0;
background: #fff;
border-radius: 20rpx;
.title {
text-align: center;
font-size: 32rpx;
text-align: center;
color: #333;
font-weight: 700;
}
.content {
margin-top: 20rpx;
line-height: 1.5;
font-size: 26rpx;
color: #666;
navigator {
display: inline-block;
color: #e93323;
}
}
.btn-box {
margin-top: 40rpx;
text-align: center;
font-size: 30rpx;
.btn-item {
height: 82rpx;
line-height: 82rpx;
background: linear-gradient(90deg, #f67a38 0%, #f11b09 100%);
color: #fff;
border-radius: 41rpx;
}
.btn {
padding: 30rpx 0;
}
}
}
}
.coupon_popups {
z-index: 999;
position: fixed;
left: 0;
top: 0;
width: 100%;
height: 100%;
text-align: center;
.bg {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background-color: rgba(0, 0, 0, .5);
}
.con {
position: absolute;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
width: 680rpx;
height: 900rpx;
background-size: 100% 700rpx;
background-repeat: no-repeat;
scroll-view {
width: 610rpx;
height: 306rpx;
padding: 20rpx 10rpx 0;
margin: 300rpx auto 0;
box-sizing: border-box;
}
.item {
display: flex;
align-items: center;
width: 100%;
height: 164rpx;
background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABDgAAAFICAMAAACC1L7bAAAAilBMVEUAAAD////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////2N2iNAAAALXRSTlMA9xnrZyf0790ev4d1Egr7cl9TI+XNbVpAtKSUjX0NB6ucgnpDMdjRxUw7LdTK5bIiAAAF40lEQVR42uzcWW7CMBSF4UNImAIBEcpUKJQixt79b68qD1VLgNi8VHL+bxHH9tH1VUE+SeedVs1QkMmNAYGotTrzdNJWiSRtGe7J5aRnQFh2m1z3ndeGB05ycjYgOPNct2WLvuGRoZxMDAhPbbnSDQmPlDKpnCwMCNE+UsGxYSixl5MXA4JUP+lKbCgXyUHbgED1J/pjbHAwloONAcGKqfP8jVYqlTUNCNdQPxKDmw+V6hoQsEZOm+et0VOJHiUzwnbgjPQ3Uwlm6BC6WBcRZ6SHpa7QMqNimj19ezd42OqBLcO3CF/K2IG/5lR3Tbm8oQIuVd/S4CfmnYJqiyXtDJ5eM92QdAyohI6UG7zVB7qWpQZUxRufVJ4z6kb65dytG1AZR80NzzkMTkkkKY/XpAaqJWVqFICvmfiSBcDTp1hnDsDTiFX+AHzVCA4A3ggOAAQHgAKCA8D/Izi+2KmDAQAAAAZC/tYDGMB9CiJAHMARB9ATByAO4IgD6IkDEAdwxAH0xAGIAzjiAHriAMQBHHEAPXEA4gCOOICeOABxAEccQE8cgDiAIw6gJw5AHMARB9ATByAOxk4dDAAAADAQ8rcewADuUxDBEQfQEwcgDuCIA+iJAxAHcMQB9MQBiAM44gB64gDEARxxAD1xAOIAjjiAnjgAcQBHHEBPHIA4gCMOoCcOQBzAEQfQEwcgDuCIA+iJAxAHcMQB9MQBiAM44gB64gDEARxxAD1xAOIAjjiAnjgAcQBHHEBPHIA4gCMOoCcOQBzAEQfQEwcgDuCIA+iJAxAHcMQB9MQBjJ06GAAAAGAg5G89gAHcpyASB3DEAfTEAYgDOOIAeuIAxAEccQA9cQDiAI44gJ44AHEARxxATxyAOIAjDqAnDkAcwBEH0BMHIA7giAPoiQMQB3DEAfTEAYgDOOIAeuIAxAEccQA9cQDiAI44gJ44AHEARxxATxyAOIAjDqAnDkAcwBEH0BMHIA7giAPoiQMQB3DEAfTEAYgDOOIAeuIAxAEccQA9cTB26mAAAACAgZC/9QAOYJ+CCMQBhDiAP3EA4gBCHMCfOABxACEO4E8cgDiAEAfwJw5AHECIA/gTByAOIMQB/IkDEAcQ4gD+xAGIAwhxAH/iAMQBhDiAP3EA4gBCHMCfOABxACEO4E8cgDiAEAfwJw5AHECIA/gTByAOIMQB/IkDEAcQ4gD+xAGIAwhxAH/iAMQBhDiAP3EA4gBCHMCfOABxACEOYOzUwQAAAAADIX/rAQzgPgVRTxyAOIAjDqAnDkAcwBEH0BMHIA7giAPoiQMQB3DEAfTEAYgDOOIAeuIAxAEccQA9cQDiAI44gJ44AHEARxxATxyAOIAjDqAnDkAcwBEH0BMHIA7giAPoiQMQB3DEAfTEAYgDOOIAeuIAxAEccQA9cQDiAI44gJ44AHEARxxATxyAOIAjDqAnDkAcwBEH0BMHIA7giIOxU4cEAIBAEMBAIUny/esR4BTqzBZi0CcOQBxAEAfQJw5AHEAQB9AnDkAcQBAH0CcOQBxAEAfQJw5AHEAQB9AnDkAcQBAH0CcOQBxAEAfQt+4AfNnrDK+dO8tNGIaiMHwSoBAKlERAQ4FQhnSQeve/vaoPRVWayTza/7cI2/ecKwNwMtDEAMDJRFMDACdb7Qz3WZ3SRJqX2fJ1YEBI9no23GGyGemP8sLZgYBkig3uLqpaLDk6EIy5tDY42iaqsTgZEISppJnBSZSqwdKAEAwlZhVHg1KNcrZiEICHQhK9ipOoVIucRVz476wfcWToLVOroQGeG8wlkXI42akF7zeE4BbyvRv6WS3UoaCVhd+m+jUy9JPqhmoFQRrHukkNfUzU7bgywF+fXJPONmpFZATvDSttAD1it6hQMwY/+O8pVcWV3aVOW/XBFyfw1TjXP8mXod1MvewN8NE6Vo3jmU2wdrlaEDXDb9HhqHqjF0OLWL1cDfDOKVGz5PBmaCKJdBQhWl9idUiy/QczSy31UxjgjYfpYxar6hufchGebA48QgAAAABJRU5ErkJggg==');
background-repeat: no-repeat;
background-size: 100% 100%;
margin-bottom: 20rpx;
border-radius: 20rpx;
position: relative;
.left {
width: 160rpx;
text-align: center;
&::after {
content: "";
display: block;
height: 110rpx;
border-right: 1px dashed #E6E6E6;
position: absolute;
left: 178rpx;
top: 25rpx;
}
.price {
color: #E93323;
font-size: 26rpx;
font-weight: bold;
text {
font-size: 46rpx;
}
}
.max_price {
color: #999999;
font-size: 18rpx;
margin-top: 8rpx;
}
}
.right {
width: 432rpx;
padding: 0 20rpx;
.title {
color: #333333;
font-size: 26rpx;
}
.time {
color: #999999;
font-size: 22rpx;
margin-top: 20rpx;
}
.bnt1 {
.titleSize {
font-weight: 700;
font-size: 33rpx;
}
.titleColor {
margin-top: 20rpx;
color: #999999;
}
}
.coupon_type {
position: absolute;
color: #fff;
font-size: 15rpx;
width: 30rpx;
text-align: center;
height: auto;
background: #E93323;
top: 0;
right: 20rpx;
line-height: 26rpx;
padding: 5rpx 0 15rpx;
writing-mode: vertical-lr;
word-wrap: break-word;
display: flex;
/*#ifdef MP*/
align-items: center;
/*#endif*/
justify-content: center;
&::after {
content: "";
width: 0;
height: 0;
border-left: 14rpx solid transparent;
border-right: 14rpx solid transparent;
border-bottom: 14rpx solid #fff;
position: absolute;
bottom: -4rpx;
left: 2rpx;
}
}
}
}
.text {
width: 600rpx;
margin: 30rpx auto 0;
font-size: 20rpx;
color: #ffffff;
}
.icon-guanbi3 {
color: #ffffff;
font-size: 70rpx;
position: absolute;
bottom: -80rpx;
left: 320rpx;
}
}
}
.item_tags {
margin-top: 8rpx;
display: flex;
}
.item_tags .tags_item {
display: inline-block;
font-size: 20rpx;
text-align: center;
border-radius: 5rpx;
padding: 0 4rpx;
line-height: 28rpx;
margin-right: 8rpx;
}
.item_tags .tags_item.ticket {
color: var(--view-theme);
border: 1px solid var(--view-theme);
}
.item_tags .tags_item.delivery {
color: #FF9000;
border: 1px solid #FF9000;
}
.copyRight {
margin: 60rpx auto 20rpx;
max-width: 690rpx;
font-size: 20rpx;
color: #707070;
text-decoration: none;
}
.share-box {
z-index: 1000;
position: fixed;
left: 0;
top: 0;
width: 100%;
height: 100%;
image {
width: 100%;
height: 100%;
}
}
.error-network {
position: fixed;
left: 0;
top: 0;
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
height: 100%;
padding-top: 40rpx;
background: #fff;
padding-top: 30%;
image {
width: 414rpx;
height: 336rpx;
}
.title {
position: relative;
top: -40rpx;
font-size: 32rpx;
color: #666;
}
.con {
font-size: 24rpx;
color: #999;
.label {
margin-bottom: 20rpx;
}
.item {
margin-bottom: 20rpx;
}
}
.btn {
display: flex;
align-items: center;
justify-content: center;
width: 508rpx;
height: 86rpx;
margin-top: 100rpx;
border: 1px solid #d74432;
color: #e93323;
font-size: 30rpx;
border-radius: 120rpx;
}
}
.area-row {
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
display: block;
width: 100%;
text-align: center;
}
.page-index {
display: flex;
flex-direction: column;
min-height: 100%;
.page_content {
/* #ifdef MP || APP-PLUS */
padding-top: 270rpx;
/* #endif */
.page_bg {
background: linear-gradient(180deg, #fff 0%, #f5f5f5 100%);
}
.nav {
padding: 0 0rpx 30rpx;
flex-wrap: wrap;
/* #ifdef MP */
margin-top: 0;
/* #endif */
/* #ifdef H5 */
margin-top: 0;
/* #endif */
.item {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
width: 20%;
margin-top: 30rpx;
image {
width: 82rpx;
height: 82rpx;
}
}
}
.index-product-wrapper {
.nav-bd {
display: flex;
align-items: center;
.item {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
width: 25%;
.txt {
font-size: 32rpx;
color: #282828;
}
.label {
display: flex;
align-items: center;
justify-content: center;
width: 124rpx;
height: 32rpx;
margin-top: 5rpx;
font-size: 24rpx;
color: #999;
}
&.active {
color: $theme-color;
.label {
background: linear-gradient(90deg, $bg-star 0%, $bg-end 100%);
border-radius: 16rpx;
color: #fff;
}
}
}
}
.list-box {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
.item {
width: 345rpx;
margin-bottom: 20rpx;
background-color: #fff;
border-radius: 10px;
overflow: hidden;
image {
width: 100%;
height: 345rpx;
}
.text-info {
padding: 10rpx 20rpx 15rpx;
.title {
color: #222222;
}
.old-price {
margin-top: 8rpx;
font-size: 26rpx;
color: #aaaaaa;
text-decoration: line-through;
text {
margin-right: 2px;
font-size: 20rpx;
}
}
.price {
display: flex;
align-items: flex-end;
color: $theme-color;
font-size: 34rpx;
font-weight: 800;
text {
padding-bottom: 4rpx;
font-size: 24rpx;
font-weight: normal;
}
.txt {
display: flex;
align-items: center;
justify-content: center;
width: 28rpx;
height: 28rpx;
margin-left: 15rpx;
margin-bottom: 10rpx;
border: 1px solid $theme-color;
border-radius: 4rpx;
font-size: 22rpx;
font-weight: normal;
}
}
}
}
&.on {
display: flex;
}
}
}
}
}
.productList {
background-color: #f1f1f1;
min-height: 70vh;
.sort {
width: 710rpx;
max-height: 380rpx;
background: rgba(255, 255, 255, 1);
border-radius: 16rpx;
padding: 8rpx 0rpx 30rpx;
flex-wrap: wrap;
margin: 25rpx auto 0 auto;
.item {
width: 20%;
margin-top: 30rpx;
text-align: center;
.pictrues {
width: 90rpx;
height: 90rpx;
background: rgba(248, 248, 248, 1);
border-radius: 50%;
margin: 0 auto;
}
.easy-loadimage {
width: 90rpx;
height: 90rpx;
display: inline-block;
}
.text {
color: #272727;
font-size: 24rpx;
margin-top: 10rpx;
overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
}
}
}
}
.productList .list {
padding: 0 20rpx;
}
.productList .list.on {
background-color: #fff;
border-top: 1px solid #f6f6f6;
}
.productList .list .item {
width: 345rpx;
margin-top: 20rpx;
background-color: #fff;
border-radius: 10rpx;
.name {
display: flex;
align-items: center;
}
}
.productList .list .item.on {
width: 100%;
display: flex;
border-bottom: 1px solid #f6f6f6;
padding: 30rpx 0;
margin: 0;
}
.productList .list .item .pictrue {
position: relative;
width: 100%;
height: 345rpx;
}
.productList .list .item .pictrue.on {
width: 180rpx;
height: 180rpx;
}
/deep/.productList .list .item .pictrue image,
/deep/.productList .list .item .pictrue uni-image,
/deep/.productList .list .item .pictrue .easy-loadimage {
width: 100%;
height: 100%;
border-radius: 10rpx 10rpx 0 0;
}
/deep/.productList .list .item .pictrue uni-image.origin-img {
border-radius: 10rpx 10rpx 0 0;
}
.productList .list .item .pictrue image.on {
border-radius: 6rpx;
}
.productList .list .item .text {
padding: 14rpx 17rpx 26rpx 17rpx;
font-size: 28rpx;
color: #212121;
}
.productList .list .item .text.on {
width: 508rpx;
padding: 0 0 0 22rpx;
}
.productList .list .item .text .money {
font-size: 26rpx;
font-weight: bold;
margin-top: 8rpx;
}
.productList .list .item .text .coupon {
background: rgba(255, 248, 247, 1);
border: 1px solid rgba(233, 51, 35, 1);
border-radius: 4rpx;
font-size: 20rpx;
margin-left: 18rpx;
padding: 1rpx 4rpx;
}
.productList .list .item .text .money.on {
margin-top: 50rpx;
}
.productList .list .item .text .money .num {
font-size: 34rpx;
}
.pictrue {
position: relative;
.border-picture {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
border-radius: 10rpx 10rpx 0 0;
background: center/cover no-repeat;
}
}
.cate_pictrue,
/deep/.cate_pictrue image,
/deep/.cate_pictrue .easy-loadimage,
/deep/.cate_pictrue uni-image {
width: 82rpx;
height: 82rpx;
margin: 0 auto;
}
.fixed {
z-index: 100;
position: fixed;
left: 0;
top: 0;
background-color: #fff;
box-shadow: 0 10rpx 20rpx -5rpx rgba(0, 0, 0, 0.06);
}
.page-footer {
position: fixed;
bottom: 0;
z-index: 30;
display: flex;
align-items: center;
justify-content: space-around;
width: 100%;
height: calc(98rpx+ constant(safe-area-inset-bottom)); ///兼容 IOS<11.2/
height: calc(98rpx + env(safe-area-inset-bottom)); ///兼容 IOS>11.2/
box-sizing: border-box;
border-top: 1px solid #F3F3F3;
background-color: #fff;
box-shadow: 0px 0px 17rpx 1rpx rgba(206, 206, 206, 0.32);
padding-bottom: constant(safe-area-inset-bottom); ///兼容 IOS<11.2/
padding-bottom: env(safe-area-inset-bottom); ///兼容 IOS>11.2/
&.filter {
filter: blur(2rpx);
}
.foot-item {
display: flex;
width: max-content;
align-items: center;
justify-content: center;
flex-direction: column;
position: relative;
.count-num {
position: absolute;
display: flex;
justify-content: center;
align-items: center;
width: 40rpx;
height: 40rpx;
top: 0rpx;
right: -15rpx;
color: #fff;
font-size: 20rpx;
background-color: #FD502F;
border-radius: 50%;
padding: 4rpx;
}
}
.foot-item image {
height: 50rpx;
width: 50rpx;
text-align: center;
margin: 0 auto;
}
.foot-item .txt {
font-size: 24rpx;
}
}
</style>