overseas/pages/index/index.vue

1638 lines
46 KiB
Vue

<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>
<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"></homeComb>
<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"></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 v-if="item.name == 'menus'" :class="isMenu ? 'transform-view' : ''" :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"
@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 :hostProduct="hostProduct" :indexP="true" :isLogin="isLogin"></recommend>
<view class="loadingicon acea-row row-center-wrapper" v-if="hostProduct.length > 0">
<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">
HK$
<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" class="copyRight">{{beian_sn}}</a>
<!-- #endif -->
<!-- #ifndef H5 -->
<view v-if="beian_sn" class="copyRight" @click="goCopyright('https://beian.miit.gov.cn')">{{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">HK$ <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>
var statusBarHeight = uni.getSystemInfoSync().statusBarHeight + 'px';
let app = getApp();
import { getUserInfo } from '@/api/user.js';
import { getDiy, getPageDiy, getIndexData, getAppVersion } 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';
// #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,
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: {},
currSpid: '',
_options:{},
isIntegral: false,
appUpdate: {},
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: {
goCopyright(url){
this.$util.JumpPath(url);
},
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');
},
// 重新链接
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;
},
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)
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.get_host_product()
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();
// that.updataDowload();
});
})
},
updataDowload(){
//#ifdef APP-PLUS
var that = this;
switch (uni.getSystemInfoSync().platform) {
case 'android':
uni.showModal({
title: '更新提示',
content: '检测到新版本,即将进入更新',
showCancel: false,
success: (res) => {
if (res.confirm) {
const downloadTask = uni.downloadFile({
url: that.appUpdate.androidAddress,
success: (downloadResult) => {
if (downloadResult.statusCode === 200) {
plus.runtime.install(
downloadResult.tempFilePath,
{
force: true
},
function (e) {
uni.showModal({
title: '更新成功',
content: '更新完成,请重新启动app',
showCancel: false,
success: (res) => {
plus.runtime.quit();
}
});
},
function (e) {
uni.showModal({
title: '更新失败',
content: JSON.stringify(e),
showCancel: false,
success: (res) => {
console.log(res);
}
});
}
);
}
}
});
var showLoading = plus.nativeUI.showWaiting('正在下载'); //创建一个showWaiting对象
downloadTask.onProgressUpdate((res) => {
showLoading.setTitle(' 正在下载' + res.progress + '% ');
// 测试条件,取消下载任务。
if (res.progress === 100) {
plus.nativeUI.closeWaiting();
}
});
}
}
});
break;
case 'ios':
if (that.appUpdate.iosAddress) {
uni.showModal({
title:"更新提示",
content: '检测到新版本,即将进入更新',
success:(res)=> {
if(res.confirm){
plus.runtime.openURL(data.appstore);
}
}
})
}
break;
}
},
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,tabTitle) {
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.navTop = tabTitle;
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 = '加载更多';
});
},
/**
* 获取我的推荐
*/
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);
});
},
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.get_host_product();
}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%;
}
.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>