2020-08-13 08:12:57 +00:00
< template >
< view class = "page-index copy-data" : class = "{'bgf':navIndex >0}" :data-clipboard-text ="copywords" >
<!-- # ifdef H5 -- >
< view class = "header" >
< view class = "serch-wrapper flex" >
< view class = "logo" >
<!-- < image v-if ="!logoUrl" class="logo" src="/static/images/crmeb.png" > < / image > - - >
< image :src ="logoUrl" mode = "" > < / image >
< / view >
< navigator url = "/pages/goods_search/index" class = "input" hover -class = " none " > < text class = "iconfont icon-xiazai5" > < / text >
搜索商品 < / navigator >
< / view >
< tabNav class = "tabNav" :class ="{'fixed':isFixed}" :tabTitle ="navTop" @ changeTab = 'changeTab' @ emChildTab = 'emChildTab'
@ childTab = 'childTab' > < / tabNav >
< / view >
<!-- # endif -- >
<!-- # ifdef MP -- >
< view class = "mp-header" >
< view class = "sys-head" view : style = "{ height: statusBarHeight }" > < / view >
< view class = "serch-box" view style = "height: 43px;" >
< view class = "serch-wrapper flex" >
< view class = "logo" >
<!-- < image class = "logo" src = "/static/images/crmeb.png" > < / image > -- >
< image :src ="logoUrl" mode = "" > < / image >
< / view >
< navigator url = "/pages/goods_search/index" class = "input" hover -class = " none " > < text class = "iconfont icon-xiazai5" > < / text >
搜索商品 < / navigator >
< / view >
< / view >
< tabNav class = "tabNav" :tabTitle ="navTop" @ changeTab = 'changeTab' > < / tabNav >
< / view >
<!-- # endif -- >
<!-- 首页展示 -- >
< view class = "page_content" :style ="'margin-top:'+(marTop+30)+'px;'" v-if ="navIndex == 0" >
<!-- # ifdef MP -- >
< view class = "mp-bg" > < / view >
<!-- # endif -- >
<!-- banner -- >
< view class = "swiper" >
< swiper indicator -dots = " true " :autoplay ="true" :circular ="circular" :interval ="interval" :duration ="duration"
indicator - color = "rgba(255,255,255,0.6)" indicator - active - color = "#fff" >
< block v-for ="(item,index) in imgUrls" :key ="index" >
< swiper -item >
< navigator : url = 'item.url' class = 'slide-navigator acea-row row-between-wrapper' hover -class = ' none ' >
< image :src ="item.pic" class = "slide-image" > < / image >
< / navigator >
< / s w i p e r - i t e m >
< / block >
< / swiper >
< / view >
<!-- menu -- >
< view class = 'nav acea-row' v-if ="menus.length" >
< block v-for ="(item,index) in menus" :key ="index" >
< navigator class = 'item' v -if = " item.show = = ' 1 ' " : url = 'item.url' open -type = ' switchTab ' hover -class = ' none ' >
< view class = 'pictrue' >
< image : src = 'item.pic' > < / image >
< / view >
< view class = "menu-txt" > { { item . name } } < / view >
< / navigator >
< navigator class = 'item' v -else : url = 'item.url' hover -class = ' none ' >
< view class = 'pictrue' >
< image : src = 'item.pic' > < / image >
< / view >
< view class = "menu-txt" > { { item . name } } < / view >
< / navigator >
< / block >
< / view >
<!-- 直播 -- >
<!-- # ifdef MP -- >
< block v-if ="liveList.length>0" >
< navigator :url ="'plugin-private://wx2b03c6e691cd7370/pages/live-player-plugin?room_id='+liveList[0].roomid" class = "live-wrapper"
v - if = "liveList.length==1" hover - class = "none" >
< view class = "live-top" : class = "liveList[0].live_status == 101?'pictrue_log_xl':liveList[0].live_status == 103?'pictrue_log_xl_gray':'pictrue_log_xl_blue'" >
< block v-if ="liveList[0].live_status == 101" >
< image src = "/static/images/live-01.png" mode = "" > < / image >
< text > 直播中 < / text >
< / block >
< block v-if ="liveList[0].live_status == 103" >
< image src = "/static/images/live-02.png" mode = "" > < / image >
< text > 已结束 < / text >
< / block >
< block v-if ="liveList[0].live_status == 102" >
< image src = "/static/images/live-03.png" mode = "" > < / image >
< text > 未开始 < / text >
< / block >
< / view >
< image :src ="liveList[0].share_img" > < / image >
< view class = "live-title line1" > { { liveList [ 0 ] . name } } < / view >
< / navigator >
< view class = "live-wrapper mores" v-else >
< scroll -view scroll -x = " true " style = "white-space: nowrap; display: flex" >
< navigator hover -class = " none " class = "item" v-for ="(item,index) in liveList" :key="index" :url="'plugin-private://wx2b03c6e691cd7370/pages/live-player-plugin?room_id='+item.roomid" >
< view class = "live-top" : class = "item.type == 1?'pictrue_log_xl':item.type == 2?'pictrue_log_xl_gray':'pictrue_log_xl_blue'" >
< block v-if ="item.live_status == 101" >
< image src = "/static/images/live-01.png" mode = "" > < / image >
< text > 直播中 < / text >
< / block >
< block v-if ="item.live_status == 103" >
< image src = "/static/images/live-02.png" mode = "" > < / image >
< text > 已结束 < / text >
< / block >
< block v-if ="item.live_status == 102" >
< image src = "/static/images/live-03.png" mode = "" > < / image >
< text > 未开始 < / text >
< / block >
< / view >
< image :src ="item.share_img" > < / image >
< view class = "live-title" > { { item . name } } < / view >
< / navigator >
< / s c r o l l - v i e w >
< / view >
< / block >
<!-- # endif -- >
<!-- 拼团热点图 -- >
< view class = "hot-img" :style ="{'marginTop':liveList.length>0?'40rpx':'0'}" >
< swiper :autoplay ="autoplay" :circular ="circular" :interval ="interval" >
< block v-for ="(item,index) in activityList" :key ="index" >
< swiper -item >
< navigator : url = 'item.link' class = 'slide-navigator acea-row row-between-wrapper' hover -class = ' none ' >
< image :src ="item.image" class = "slide-image" > < / image >
< / navigator >
< / s w i p e r - i t e m >
< / block >
< / swiper >
< / view >
<!-- 超值爆款 -- >
< view class = "explosion" >
< view class = "hd" >
< image src = "/static/images/explosion-title.png" mode = "" > < / image >
< view class = "txt" > 美好生活由此开始 < / view >
< / view >
< view class = "bd" >
< navigator class = "item" v -for = " ( item , index ) in explosiveMoney " :key ="index" :url ="'/pages/columnGoods/HotNewGoods/index?type='+item.type"
hover - class = 'none' >
< view class = "con-box" >
< view class = "title line1" > { { item . title } } < / view >
< view class = "con line2" > { { item . info } } < / view >
< view class = "go" > GO ! < image src = "/static/images/right-icon.png" mode = "" > < / image >
< / view >
< / view >
< image :src ="item.image" > < / image >
< / navigator >
< / view >
< / view >
<!-- 限时秒杀 -- >
< view class = "spike-box" v-if ="spikeList.length>0" >
< view class = "hd" >
< view class = "left" >
< image src = "/static/images/spike-icon-002.gif" class = "icon" > < / image >
< image src = "/static/images/spike-icon-001.png" class = "title" > < / image >
< countDown :is-day ="false" : tip -text = " ' ' " : day -text = " ' ' " : hour -text = " ' : ' " : minute -text = " ' : ' " : second -text = " ' ' "
: datatime = "datatime" > < / countDown >
< / view >
< navigator class = "more" url = "/pages/activity/goods_seckill/index" > 更多 < text class = "iconfont icon-jiantou"
hover - class = 'none' > < / text > < / navigator >
< / view >
< view class = "spike-wrapper" >
< scroll -view scroll -x = " true " style = "white-space: nowrap; display: flex" show -scrollbar = " false " >
< navigator class = "spike-item" v -for = " ( item , index ) in spikeList " :key ="index" :url ="'/pages/activity/goods_seckill_details/index?id='+item.id+'&time='+datatime+'&status=1'"
hover - class = 'none' >
< view class = "img-box" >
< image :src ="item.image" mode = "" > < / image >
< view class = "msg flex-aj-center" > { { item . discountNum } } 折起 < / view >
< / view >
< view class = "info" >
< view class = "name line1" > { { item . title } } < / view >
< view class = "price-box" >
< text class = "tips" > 抢 < / text >
< text class = "price" > < text > ¥ < / text > { { item . price } } < / text >
< / view >
< / view >
< / navigator >
< / s c r o l l - v i e w >
< / view >
< / view >
<!-- 砍价专区 -- >
< view class = "barg" v-if ="bargList.length>0" >
< view class = "title" >
< image src = "/static/images/barg001.png" mode = "" > < / image >
< / view >
< view class = "barg-swiper" >
< scroll -view scroll -x = " true " style = "white-space: nowrap; display: flex" show -scrollbar = " true " >
< view class = "wrapper" >
< block v-for ="(item,index) in bargList" :key ="index" >
< view class = 'list-box' @click ="bargDetail(item)" >
< image :src ="item.image" class = "slide-image" > < / image >
< view class = "info-txt" >
< view class = "price" > ¥ { { item . price } } < / view >
< view class = "txt" > 立即砍价 < / view >
< / view >
< / view >
< / block >
< navigator url = "/pages/activity/goods_bargain/index" class = "more-box" hover -class = " none " >
< view class = "txt" > 查看更多 < / view >
< image src = "/static/images/mores.png" > < / image >
< / navigator >
< / view >
< / s c r o l l - v i e w >
< / view >
< / view >
<!-- 拼团活动 -- >
< view class = "group-wrapper" v-if ="combinationList.length>0" >
< view class = "hd" >
< view class = "left" >
< image src = "/static/images/group02.gif" class = "icon" > < / image >
< image src = "/static/images/group01.png" class = "title" > < / image >
< view class = "person" >
< view class = "avatar-box" >
< block v-for ="item in pinkInfo.avatars" >
< image :src ="item" mode = "" > < / image >
< / block >
< / view >
< view class = "num" v-if ="pinkInfo.pink_count>0" > {{ pinkInfo.pink_count }} 人 拼 团 成 功 < / view >
< / view >
< / view >
< navigator class = "more" url = "/pages/activity/goods_combination/index" hover -class = " none " > 更多 < text class = "iconfont icon-jiantou" > < / text > < / navigator >
< / view >
< view class = "group-scroll" >
< scroll -view scroll -x = " true " style = "white-space: nowrap; display: flex" show -scrollbar = " false " >
< navigator class = "group-item" v -for = " ( item , index ) in combinationList " :key ="index" :url ="'/pages/activity/goods_combination_details/index?id='+item.id"
hover - class = "none" >
< image :src ="item.image" mode = "" > < / image >
< view class = "info" >
< view class = "name line1" > { { item . title } } < / view >
< view class = "price-box" >
< text class = "tips" > 拼团价 < / text >
< text class = "price" > < text > ¥ < / text > { { item . price } } < / text >
< / view >
< / view >
< view class = "bom-btn" > 参与拼团 < / view >
< / navigator >
< / s c r o l l - v i e w >
< / view >
< / view >
<!-- 精品推荐 -- >
< view class = 'boutique' >
< swiper autoplay = "true" indicator -dots = " true " :circular ="circular" :interval ="interval" :duration ="duration"
indicator - color = "rgba(0,0,0,.4)" indicator - active - color = "#fff" >
< block v-for ="(item,index) in bastBanner" :key ="index" >
< swiper -item >
< navigator : url = 'item.link' style = 'width:100%;height:100%;' hover -class = ' none ' >
< image :src ="item.img" class = "slide-image" / >
< / navigator >
< / s w i p e r - i t e m >
< / block >
< / swiper >
< / view >
<!-- 首页推荐 -- >
< view class = "index-product-wrapper" style = "min-height: 1500rpx;" >
< view class = "nav-bd" >
2020-08-17 07:28:28 +00:00
< view class = "item" v -for = " ( item , index ) in explosiveMoney " :key ="index" :index ="item.id" : class = "{active:index == ProductNavindex}"
2020-08-13 08:12:57 +00:00
@ click = "ProductNavTab(item,index)" >
< view class = "txt" > { { item . title } } < / view >
< view class = "label" > { { item . info2 } } < / view >
< / view >
< / view >
<!-- 首发新品 -- >
< view class = "list-box animated" : class = 'tempArr.length > 0?"fadeIn on":""' >
< view class = "item" v-for ="(item,index) in tempArr" :key="index" @click="goDetail(item)" >
< view class = "pictrue" >
< span class = "pictrue_log pictrue_log_class" v-if ="item.activity && item.activity.type === '1'" > 秒 杀 < / span >
< span class = "pictrue_log pictrue_log_class" v-if ="item.activity && item.activity.type === '2'" > 砍 价 < / span >
< span class = "pictrue_log pictrue_log_class" v-if ="item.activity && item.activity.type === '3'" > 拼 团 < / span >
< image :src ="item.image" mode = "" > < / image >
< / view >
< view class = "text-info" >
< view class = "title line1" > { { item . store _name } } < / view >
< view class = "old-price" > < text > ¥ < / text > { { item . ot _price } } < / view >
< view class = "price" >
< text > ¥ < / text > { { item . price } }
< view class = "txt" v-if ="item.checkCoupon" > 券 < / view >
< / view >
< / view >
< / view >
< / view >
< view class = 'loadingicon acea-row row-center-wrapper' v-if ="goodScroll" >
< text class = 'loading iconfont icon-jiazai' : hidden = 'loading==false' > < / text >
< / view >
< view class = "mores-txt flex" v-if ="!goodScroll" >
< text > 我是有底线的 < / text >
< / view >
< / view >
< / view >
<!-- 分类页 -- >
< view class = "productList" v-if ="navIndex>0" :style="'margin-top:'+prodeuctTop+'px'" >
< block v-if ="sortProduct.length>0" >
< view class = 'list acea-row row-between-wrapper' : class = 'is_switch==true?"":"on"' >
< view class = 'item' : class = 'is_switch==true?"":"on"' hover -class = ' none ' v -for = " ( item , index ) in sortProduct " :key ="index"
@ click = "godDetail(item)" >
< view class = 'pictrue' : class = 'is_switch==true?"":"on"' >
< image : src = 'item.image' : class = 'is_switch==true?"":"on"' > < / image >
< span class = "pictrue_log_class" : class = "is_switch === true ? 'pictrue_log_big' : 'pictrue_log'" v-if ="item.activity && item.activity.type === '1'" > 秒 杀 < / span >
< span class = "pictrue_log_class" : class = "is_switch === true ? 'pictrue_log_big' : 'pictrue_log'" v-if ="item.activity && item.activity.type === '2'" > 砍 价 < / span >
< span class = "pictrue_log_class" : class = "is_switch === true ? 'pictrue_log_big' : 'pictrue_log'" v-if ="item.activity && item.activity.type === '3'" > 拼 团 < / span >
< / view >
< view class = 'text' : class = 'is_switch==true?"":"on"' >
< view class = 'name line1' > { { item . store _name } } < / view >
< view class = 'money font-color' : class = 'is_switch==true?"":"on"' > ¥ < text class = 'num' > { { item . price } } < / text > < / view >
< view class = 'vip acea-row row-between-wrapper' : class = 'is_switch==true?"":"on"' >
< view class = 'vip-money' v-if ="item.vip_price && item.vip_price > 0" > ¥ {{ item.vip_price }}
< image src = '../../static/images/vip.png' > < / image >
< / view >
< view > 已售 { { item . sales } } 件 < / view >
< / view >
< / view >
< / view >
< view class = 'loadingicon acea-row row-center-wrapper' v -if = ' sortProduct.length > 0 ' >
< 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' >
< image src = '/static/images/noShopper.png' > < / image >
< / view >
< recommend :hostProduct ="hostProduct" > < / recommend >
< / view >
< / block >
< / view >
< coupon -window : window = 'window' :couponList ="couponList" @onColse ="onColse" > < / coupon -window >
<!-- # ifdef MP -- >
< authorize @onLoadFun ="onLoadFun" :isAuto ="isAuto" :isShowAuth ="isShowAuth" @authColse ="authColse" :isGoIndex ="false" > < / authorize >
<!-- # endif -- >
< / view >
< / template >
< script >
var statusBarHeight = uni . getSystemInfoSync ( ) . statusBarHeight + 'px' ;
let app = getApp ( ) ;
import {
getIndexData ,
getCoupons ,
pink
} from '@/api/api.js' ;
// #ifdef MP-WEIXIN
import {
getTemlIds ,
getLiveList
} from '@/api/api.js' ;
import {
SUBSCRIBE _MESSAGE ,
TIPS _KEY
} from '@/config/cache' ;
// #endif
// #ifdef H5
import {
getShare ,
follow
} from '@/api/public.js' ;
// #endif
import {
copyWords
} from '@/api/public.js' ;
import goodList from '@/components/goodList' ;
import promotionGood from '@/components/promotionGood' ;
import couponWindow from '@/components/couponWindow' ;
import ClipboardJS from "@/plugin/clipboard/clipboard.js" ;
import {
goShopDetail
} from '@/libs/order.js'
import {
mapGetters
} from "vuex" ;
import tabNav from '@/components/tabNav.vue'
import {
getSeckillIndexTime ,
getSeckillList ,
getBargainList ,
getCombinationList
} from '@/api/activity.js' ;
import countDown from '@/components/countDown' ;
import {
getCategoryList ,
getProductslist ,
getProductHot ,
getGroomList
} from '@/api/store.js' ;
import {
setVisit
} from '@/api/user.js'
import recommend from '@/components/recommend' ;
// #ifdef MP
import authorize from '@/components/Authorize' ;
// #endif
import {
silenceBindingSpread
} from '@/utils' ;
export default {
computed : mapGetters ( [ 'isLogin' , 'uid' ] ) ,
components : {
tabNav ,
goodList ,
promotionGood ,
couponWindow ,
countDown ,
recommend ,
// #ifdef MP
authorize
// #endif
} ,
data ( ) {
return {
loading : false ,
isAuto : false , //没有授权的不会自动授权
isShowAuth : false , //是否隐藏授权
statusBarHeight : statusBarHeight ,
navIndex : 0 ,
navTop : [ ] ,
subscribe : false ,
followUrl : "" ,
followHid : true ,
followCode : false ,
logoUrl : "" ,
imgUrls : [ ] ,
itemNew : [ ] ,
activityList : [ ] ,
menus : [ ] ,
bastBanner : [ ] ,
bastInfo : '' ,
bastList : [ ] ,
fastInfo : '' ,
fastList : [ ] ,
firstInfo : '' ,
firstList : [ ] ,
salesInfo : '' ,
likeInfo : [ ] ,
benefit : [ ] ,
indicatorDots : false ,
circular : true ,
autoplay : true ,
interval : 3000 ,
duration : 500 ,
window : false ,
iShidden : false ,
navH : "" ,
newGoodsBananr : '' ,
couponList : [ ] ,
lovely : [ ] ,
liveList : [ ] ,
spikeList : [ ] ,
combinationList : [ ] ,
hotList : [ {
pic : '/static/images/hot_001.png'
} , {
pic : '/static/images/hot_002.png'
} , {
pic : '/static/images/hot_003.png'
} ] ,
bargList : [ ] ,
ProductNavindex : 0 ,
marTop : 0 ,
datatime : 0 ,
childID : 0 ,
loadend : false ,
loading : false ,
loadTitle : '加载更多' ,
sortProduct : [ ] ,
where : {
cid : 0 ,
page : 1 ,
limit : 20 ,
} ,
is _switch : true ,
hostProduct : [ ] ,
hotPage : 1 ,
hotLimit : 10 ,
hotScroll : false ,
explosiveMoney : [ ] ,
prodeuctTop : 0 ,
pinkInfo : '' ,
searchH : 0 ,
isFixed : false ,
goodType : 0 , //精品推荐Type
goodScroll : true , //精品推荐开关
params : { //精品推荐分页
page : 1 ,
limit : 10 ,
} ,
tempArr : [ ] , //精品推荐临时数组
pageInfo : '' , // 精品推荐全数据
site _name : '' , //首页title
copywords : ''
}
} ,
onLoad ( ) {
uni . getLocation ( {
type : 'wgs84' ,
success : function ( res ) {
try {
uni . setStorageSync ( 'user_latitude' , res . latitude ) ;
uni . setStorageSync ( 'user_longitude' , res . longitude ) ;
} catch { }
}
} ) ;
let self = this
// #ifdef MP
// 获取小程序头部高度
this . navH = app . globalData . navHeight ;
let info = uni . createSelectorQuery ( ) . select ( ".mp-header" ) ;
info . boundingClientRect ( function ( data ) {
self . marTop = data . height
} ) . exec ( )
// #endif
// #ifndef MP
this . navH = 0 ;
// #endif
this . isLogin && silenceBindingSpread ( ) ;
Promise . all ( [ this . getAllCategory ( ) , this . getIndexConfig ( ) , this . getSeckillIndexTime ( ) , this . getBargainList ( ) , this . getCombinationList ( ) ,
this . pink ( ) , this . setVisit ( )
] ) ;
// #ifdef MP
this . getTemlIds ( )
this . getLiveList ( )
// #endif
} ,
onShow ( ) {
let self = this
uni . setNavigationBarTitle ( {
title : self . site _name
} )
this . copy ( ) ;
// #ifdef H5
this . $nextTick ( function ( ) {
const clipboard = new ClipboardJS ( ".copy-data" ) ;
clipboard . on ( "success" , ( ) => {
// this.$util.Tips({
// title: '已成功复制口令'
// });
} ) ;
} ) ;
// #endif
} ,
methods : {
copy ( ) {
let that = this ;
copyWords ( ) . then ( res => {
that . copywords = res . data . words ;
// #ifndef H5
uni . setClipboardData ( {
data : res . data . words ,
success : function ( ) {
// return that.$util.Tips({
// title: '已成功复制口令'
// });
}
} ) ;
// #endif
} )
} ,
// #ifdef MP
getTemlIds ( ) {
let messageTmplIds = wx . getStorageSync ( SUBSCRIBE _MESSAGE ) ;
if ( ! messageTmplIds ) {
getTemlIds ( ) . then ( res => {
if ( res . data )
wx . setStorageSync ( SUBSCRIBE _MESSAGE , JSON . stringify ( res . data ) ) ;
} )
}
} ,
// #endif
// 关闭优惠券弹窗
onColse ( ) {
this . $set ( this , "window" , false ) ;
} ,
// 记录会员访问
setVisit ( ) {
setVisit ( {
url : '/pages/index/index'
} ) . then ( res => {
console . log ( res )
} )
} ,
// 获取导航
getAllCategory : function ( ) {
let that = this ;
getCategoryList ( ) . then ( res => {
res . data . unshift ( {
'name' : '首页'
} )
that . navTop = res . data ;
console . log ( res . data ) ;
} )
} ,
// 导航分类切换
changeTab ( e ) {
let self = this
if ( e . type == 'big' ) {
if ( e . index == 0 ) {
this . navIndex = e . index
} else {
// #ifdef MP
setTimeout ( res => {
this . navH = app . globalData . navHeight ;
let info = uni . createSelectorQuery ( ) . select ( ".mp-header" ) ;
info . boundingClientRect ( function ( data ) {
self . prodeuctTop = data . height
} ) . exec ( )
} , 300 )
// #endif
// #ifdef H5
self . prodeuctTop = 18
// #endif
this . navIndex = e . index
if ( this . navTop [ e . index ] . children . length > 0 ) {
this . where . cid = this . navTop [ e . index ] . children [ 0 ] . id
} else {
this . where . cid = this . navTop [ e . index ] . id
}
this . loadend = false
this . loading = false
this . where . page = 1
this . sortProduct = [ ]
this . get _product _list ( )
}
} else {
this . navIndex = e . parentIndex
this . where . cid = this . navTop [ e . parentIndex ] . children [ e . childIndex ] . id
this . loadend = false
this . loading = false
this . where . page = 1
this . sortProduct = [ ]
this . get _product _list ( )
}
} ,
//分类产品
get _product _list : function ( isPage ) {
let that = this ;
if ( that . loadend ) return ;
if ( that . loading ) return ;
// if (isPage === true) that.$set(that, 'productList', []);
that . loading = true ;
that . loadTitle = '' ;
getProductslist ( that . where ) . then ( res => {
if ( that . where . page == 1 && res . data . length == 0 ) {
that . hotScroll = false
that . hotPage = 1
that . hostProduct = [ ]
this . get _host _product ( )
}
let list = res . data ;
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 ;
that . loading = true ;
if ( that . hotScroll ) return
getProductHot (
that . hotPage ,
that . hotLimit ,
) . then ( res => {
that . hotPage ++
that . hotScroll = res . data . length < that . hotLimit
that . hostProduct = that . hostProduct . concat ( res . data )
// that.$set(that, 'hostProduct', res.data)
} ) ;
} ,
// 首页数据
getIndexConfig : function ( ) {
let that = this ;
getIndexData ( ) . then ( res => {
uni . setNavigationBarTitle ( {
title : res . data . site _name
} )
that . $set ( that , "logoUrl" , res . data . logoUrl ) ;
that . $set ( that , "site_name" , res . data . site _name ) ;
that . $set ( that , "imgUrls" , res . data . banner ) ;
that . $set ( that , "menus" , res . data . menus ) ;
that . $set ( that , "activityList" , res . data . activity ) ;
that . lovely = res . data . lovely
that . $set ( that , "pageInfo" , res . data )
that . $set ( that , "firstList" , res . data . info . firstList ) ;
that . $set ( that , "bastList" , res . data . info . bastList ) ;
that . $set ( that , "likeInfo" , res . data . likeInfo ) ;
that . $set ( that , "benefit" , res . data . benefit ) ;
that . $set ( that , "bastBanner" , res . data . info . bastBanner ) ;
that . $set ( that , "couponList" , res . data . couponList ) ;
that . explosiveMoney = res . data . explosive _money
that . goodType = res . data . explosive _money [ 0 ] . type
// #ifdef H5
that . subscribe = res . data . subscribe ;
that . setOpenShare ( ) ;
// #endif
// 小程序判断用户是否授权;
// #ifdef MP
uni . getSetting ( {
success ( res ) {
if ( ! res . authSetting [ 'scope.userInfo' ] ) {
that . window = that . couponList . length ? true : false ;
} else {
that . window = false ;
that . iShidden = true ;
}
}
} ) ;
// #endif
// #ifndef MP
if ( that . isLogin ) {
that . window = false ;
} else {
that . window = that . couponList . length ? true : false ;
}
// #endif
this . getGroomList ( ) ;
} )
} ,
// 微信分享;
setOpenShare : function ( ) {
let that = this ;
if ( that . $wechat . isWeixin ( ) ) {
getShare ( ) . then ( res => {
let data = res . data . data ;
let configAppMessage = {
desc : data . synopsis ,
title : data . title ,
link : location . href ,
imgUrl : data . img
} ;
that . $wechat . wechatEvevt ( [ "updateAppMessageShareData" , "updateTimelineShareData" ] , configAppMessage ) ;
} )
}
} ,
// 秒杀
getSeckillIndexTime ( ) {
let params = {
page : 1 ,
limit : 6 ,
type : 'index'
}
getSeckillIndexTime ( ) . then ( res => {
this . datatime = res . data . seckillTime [ res . data . seckillTimeIndex ] . stop
let id = res . data . seckillTime [ res . data . seckillTimeIndex ] . id
getSeckillList ( id , params ) . then ( ( {
data
} ) => {
data . forEach ( ( item ) => {
let num = ( ( parseFloat ( item . price ) / parseFloat ( item . ot _price ) ) . toFixed ( 2 ) )
item . discountNum = this . $util . $h . Mul ( num , 10 )
} )
this . spikeList = data
} )
} )
} ,
// 砍价列表
getBargainList ( ) {
getBargainList ( {
page : 1 ,
limit : 20
} ) . then ( res => {
this . bargList = res . data
} )
} ,
// 拼团列表
getCombinationList : function ( ) {
var that = this ;
var data = {
page : 1 ,
limit : 6
} ;
getCombinationList ( data ) . then ( function ( res ) {
var combinationList = that . combinationList ;
that . combinationList = combinationList . concat ( res . data ) ;
} ) . catch ( ( ) => {
that . loading = false
} )
} ,
// 拼团数据
pink : function ( ) {
pink ( ) . then ( res => {
this . pinkInfo = res . data
} )
} ,
// 砍价详情
bargDetail ( item ) {
if ( ! 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
this . $set ( this , 'isAuto' , true ) ;
this . $set ( this , 'isShowAuth' , true ) ;
// #endif
} else {
uni . navigateTo ( {
url : ` /pages/activity/goods_bargain_details/index?id= ${ item . id } &bargain= ${ this . uid } `
} )
}
} ,
// 授权关闭
authColse : function ( e ) {
this . isShowAuth = e
} ,
// 授权回调
onLoadFun ( ) {
} ,
// 首发新品切换
ProductNavTab ( item , index ) {
this . goodType = item . type
this . ProductNavindex = index
this . tempArr = [ ]
this . params . page = 1
this . goodScroll = true
this . getGroomList ( )
} ,
// 首发新品详情
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
this . $set ( this , 'isAuto' , true ) ;
this . $set ( this , 'isShowAuth' , true ) ;
// #endif
return
} else {
goShopDetail ( item , this . uid ) . then ( res => {
uni . navigateTo ( {
url : ` /pages/goods_details/index?id= ${ item . id } `
} )
} )
}
} ,
// 分类详情
godDetail ( item ) {
goShopDetail ( item , this . uid ) . then ( res => {
uni . navigateTo ( {
url : ` /pages/goods_details/index?id= ${ item . id } `
} )
} )
} ,
// 直播
getLiveList : function ( ) {
getLiveList ( 1 , 20 ) . then ( res => {
this . liveList = res . data
} ) . catch ( res => {
} )
} ,
// 精品推荐
getGroomList ( ) {
this . loading = true
let type = this . goodType ;
if ( ! this . goodScroll ) return
getGroomList ( type , this . params ) . then ( ( {
data
} ) => {
this . loading = false
this . goodScroll = data . list . length >= this . params . limit
this . params . page ++
this . tempArr = this . tempArr . concat ( data . list )
} )
}
} ,
mounted ( ) {
let self = this
// #ifdef H5
// 获取H5 搜索框高度
let appSearchH = uni . createSelectorQuery ( ) . select ( ".serch-wrapper" ) ;
appSearchH . boundingClientRect ( function ( data ) {
self . searchH = data . height
} ) . exec ( )
// #endif
} ,
// 滚动到底部
onReachBottom ( ) {
if ( this . navIndex == 0 ) {
// 首页加载更多
if ( this . params . page != 1 ) {
this . getGroomList ( ) ;
}
} else {
// 分类栏目加载更多
if ( this . sortProduct . length > 0 ) {
this . get _product _list ( ) ;
} else {
this . get _host _product ( ) ;
}
}
} ,
// 滚动监听
onPageScroll ( e ) {
let self = this
if ( e . scrollTop >= self . searchH ) {
self . isFixed = true
} else {
self . isFixed = false
}
}
}
< / script >
< style >
page {
display : flex ;
flex - direction : column ;
height : 100 % ;
/* #ifdef H5 */
background - color : # fff ;
/* #endif */
}
< / style >
< style lang = "scss" >
/deep/ . spike - box . styleAll {
display : inline - block ;
width : 44 rpx ;
height : 40 rpx ;
line - height : 40 rpx ;
padding : 0 ;
text - align : center ;
border - radius : 8 rpx ;
}
. page - index {
display : flex ;
flex - direction : column ;
min - height : 100 % ;
background : linear - gradient ( 180 deg , # fff 0 % , # f5f5f5 100 % ) ;
// &.bgf{
// background: #fff;
// }
. header {
width : 100 % ;
height : 320 rpx ;
background : linear - gradient ( 90 deg , $bg - star 50 % , $bg - end 100 % ) ;
. serch - wrapper {
align - items : center ;
padding : 20 rpx 50 rpx 0 53 rpx ;
. logo {
width : 118 rpx ;
height : 42 rpx ;
margin - right : 30 rpx ;
}
image {
width : 118 rpx ;
height : 42 rpx ;
}
. input {
display : flex ;
align - items : center ;
width : 500 rpx ;
height : 58 rpx ;
padding : 0 0 0 30 rpx ;
background : rgba ( 247 , 247 , 247 , 1 ) ;
border : 1 px solid rgba ( 241 , 241 , 241 , 1 ) ;
border - radius : 29 rpx ;
color : # BBBBBB ;
font - size : 28 rpx ;
. iconfont {
margin - right : 20 rpx ;
}
}
}
. tabNav {
padding - top : 24 rpx ;
}
}
/* #ifdef MP */
. mp - header {
z - index : 999 ;
position : fixed ;
left : 0 ;
top : 0 ;
width : 100 % ;
/* #ifdef H5 */
padding - bottom : 20 rpx ;
/* #endif */
background : linear - gradient ( 90 deg , $bg - star 50 % , $bg - end 100 % ) ;
. serch - wrapper {
height : 100 % ;
align - items : center ;
padding : 0 50 rpx 0 53 rpx ;
image {
width : 118 rpx ;
height : 42 rpx ;
margin - right : 30 rpx ;
}
. input {
display : flex ;
align - items : center ;
width : 305 rpx ;
height : 58 rpx ;
padding : 0 0 0 30 rpx ;
background : rgba ( 247 , 247 , 247 , 1 ) ;
border : 1 px solid rgba ( 241 , 241 , 241 , 1 ) ;
border - radius : 29 rpx ;
color : # BBBBBB ;
font - size : 28 rpx ;
. iconfont {
margin - right : 20 rpx ;
}
}
}
}
/* #endif */
. page _content {
/* #ifdef H5 */
margin - top : - 140 rpx ! important ;
/* #endif */
padding : 0 20 rpx ;
. swiper {
position : relative ;
width : 710 rpx ;
height : 280 rpx ;
margin : 0 auto ;
border - radius : 10 rpx ;
overflow : hidden ;
/* #ifdef MP */
z - index : 10 ;
/* #endif */
swiper ,
. swiper - item ,
image {
width : 100 % ;
height : 280 rpx ;
border - radius : 10 rpx ;
}
}
. nav {
padding : 0 0 rpx 30 rpx ;
flex - wrap : wrap ;
. item {
display : flex ;
flex - direction : column ;
align - items : center ;
justify - content : center ;
width : 20 % ;
margin - top : 30 rpx ;
image {
width : 82 rpx ;
height : 82 rpx ;
}
}
}
. live - wrapper {
position : relative ;
width : 100 % ;
overflow : hidden ;
border - radius : 16 rpx ;
image {
width : 100 % ;
height : 400 rpx ;
}
. live - top {
z - index : 20 ;
position : absolute ;
left : 0 ;
top : 0 ;
display : flex ;
align - items : center ;
justify - content : center ;
color : # fff ;
width : 180 rpx ;
height : 54 rpx ;
border - radius : 0 rpx 0 px 18 rpx 0 px ;
image {
width : 30 rpx ;
height : 30 rpx ;
margin - right : 10 rpx ;
/* #ifdef H5 */
display : block ;
/* #endif */
}
}
. live - title {
position : absolute ;
left : 0 ;
bottom : 6 rpx ;
width : 100 % ;
height : 70 rpx ;
line - height : 70 rpx ;
text - align : center ;
font - size : 30 rpx ;
color : # fff ;
background : rgba ( 0 , 0 , 0 , .35 ) ;
}
& . mores {
width : 100 % ;
. item {
position : relative ;
width : 320 rpx ;
display : inline - block ;
border - radius : 16 rpx ;
overflow : hidden ;
margin - right : 20 rpx ;
image {
width : 320 rpx ;
height : 180 rpx ;
border - radius : 16 rpx ;
}
. live - title {
height : 40 rpx ;
line - height : 40 rpx ;
text - align : center ;
font - size : 22 rpx ;
}
. live - top {
width : 120 rpx ;
height : 36 rpx ;
font - size : 22 rpx ;
image {
width : 20 rpx ;
height : 20 rpx ;
}
}
}
}
}
. hot - img {
/* #ifndef H5 */
margin - top : 40 rpx ;
/* #endif */
swiper ,
swiper - item image {
width : 100 % ;
height : 225 rpx ;
}
}
. explosion {
width : 100 % ;
height : 500 rpx ;
margin - top : 20 rpx ;
padding : 30 rpx 20 rpx ;
background - image : url ( '~@/static/images/explosion.png' ) ;
background - size : 100 % 100 % ;
border - radius : 13 px ;
. hd {
display : flex ;
align - items : center ;
image {
width : 147 rpx ;
height : 35 rpx ;
margin - right : 20 rpx ;
}
. txt {
width : 220 rpx ;
height : 36 rpx ;
background : linear - gradient ( 90 deg , rgba ( 255 , 168 , 0 , 1 ) 0 % , rgba ( 255 , 34 , 15 , 1 ) 100 % ) ;
border - radius : 26 rpx 0 px 26 rpx 0 px ;
color : # fff ;
text - align : center ;
font - size : 22 rpx ;
box - shadow : 3 px 1 px 1 px 1 px rgba ( 255 , 203 , 199 , .8 ) ;
}
}
. bd {
display : flex ;
flex - wrap : wrap ;
margin - top : 28 rpx ;
. item {
display : flex ;
align - items : center ;
justify - content : space - between ;
position : relative ;
width : 325 rpx ;
height : 180 rpx ;
margin - bottom : 20 rpx ;
margin - right : 20 rpx ;
background - color : # fff ;
border - radius : 16 rpx ;
padding : 0 20 rpx ;
box - sizing : border - box ;
image {
width : 160 rpx ;
height : 160 rpx ;
}
. con - box {
display : flex ;
flex - direction : column ;
justify - content : center ;
width : 120 rpx ;
height : 100 % ;
. title {
color : # 282828 ;
font - size : 30 rpx ;
}
. con {
color : # 999999 ;
font - size : 20 rpx ;
}
. go {
display : flex ;
align - items : center ;
justify - content : center ;
margin - top : 10 rpx ;
width : 112 rpx ;
height : 36 rpx ;
border - radius : 18 rpx ;
color : # fff ;
font - size : 26 rpx ;
font - weight : bold ;
font - style : italic ;
image {
width : 26 rpx ;
height : 26 rpx ;
}
}
}
& : first - child . go {
background : linear - gradient ( 90 deg , rgba ( 75 , 196 , 255 , 1 ) 0 % , rgba ( 32 , 126 , 255 , 1 ) 100 % ) ;
}
& : nth - child ( 2 ) . go {
background : linear - gradient ( 90 deg , rgba ( 255 , 144 , 67 , 1 ) 0 % , rgba ( 255 , 83 , 29 , 1 ) 100 % ) ;
}
& : nth - child ( 3 ) . go {
background : linear - gradient ( 90 deg , rgba ( 150 , 225 , 135 , 1 ) 0 % , rgba ( 72 , 206 , 44 , 1 ) 100 % ) ;
}
& : nth - child ( 4 ) . go {
background : linear - gradient ( 90 deg , rgba ( 255 , 197 , 96 , 1 ) 0 % , rgba ( 255 , 156 , 0 , 1 ) 100 % ) ;
}
& : nth - child ( 2 n ) {
margin - right : 0 ;
}
}
}
}
. spike - box {
margin - top : 20 rpx ;
padding : 23 rpx 20 rpx ;
border - radius : 24 rpx ;
background - color : # fff ;
overflow : hidden ;
box - shadow : 0 px 0 px 16 px 3 px rgba ( 0 , 0 , 0 , 0.04 ) ;
. hd {
display : flex ;
align - items : center ;
justify - content : space - between ;
. left {
display : flex ;
align - items : center ;
width : 500 rpx ;
. icon {
width : 38 rpx ;
height : 38 rpx ;
margin - right : 8 rpx ;
}
. title {
width : 134 rpx ;
height : 33 rpx ;
}
}
. more {
font - size : 26 rpx ;
color : # 999 ;
. iconfont {
margin - left : 6 rpx ;
font - size : 25 rpx ;
}
}
}
. spike - wrapper {
width : 100 % ;
margin - top : 27 rpx ;
. spike - item {
display : inline - block ;
width : 222 rpx ;
margin - right : 20 rpx ;
. img - box {
position : relative ;
height : 222 rpx ;
image {
width : 100 % ;
height : 222 rpx ;
border - radius : 16 rpx ;
}
. msg {
position : absolute ;
left : 10 rpx ;
bottom : 16 rpx ;
width : 86 rpx ;
height : 30 rpx ;
background : rgba ( 255 , 255 , 255 , 1 ) ;
border : 1 px solid rgba ( 255 , 109 , 96 , 1 ) ;
border - radius : 6 rpx ;
font - size : 20 rpx ;
color : $theme - color ;
}
}
. info {
margin - top : 8 rpx ;
padding : 0 10 rpx ;
. name {
font - size : 28 rpx ;
}
. price - box {
display : flex ;
align - items : center ;
justify - content : center ;
. tips {
display : flex ;
align - items : center ;
justify - content : center ;
width : 28 rpx ;
height : 28 rpx ;
background - color : $theme - color ;
color : # fff ;
font - size : 20 rpx ;
border - radius : 2 px ;
}
. price {
display : flex ;
margin - left : 10 rpx ;
color : $theme - color ;
font - size : 28 rpx ;
font - weight : bold ;
text {
font - size : 18 rpx ;
}
}
}
}
}
}
}
. barg {
width : 100 % ;
height : 478 rpx ;
margin - top : 20 rpx ;
padding - left : 20 rpx ;
background - image : url ( '~@/static/images/barg002.png' ) ;
background - size : 100 % 100 % ;
. title {
display : flex ;
align - items : center ;
justify - content : center ;
padding - top : 42 rpx ;
image {
width : 463 rpx ;
height : 39 rpx ;
}
}
. barg - swiper {
margin - top : 43 rpx ;
padding - right : 20 rpx ;
. wrapper {
display : flex ;
}
. list - box {
flex - shrink : 0 ;
width : 210 rpx ;
background - color : # fff ;
border - radius : 16 rpx ;
overflow : hidden ;
padding - bottom : 18 rpx ;
margin - right : 20 rpx ;
image {
width : 100 % ;
height : 210 rpx ;
}
. info - txt {
width : 100 % ;
display : flex ;
flex - direction : column ;
align - items : center ;
justify - content : center ;
padding - top : 15 rpx ;
. price {
font - weight : 700 ;
color : $theme - color ;
}
. txt {
display : flex ;
align - items : center ;
justify - content : center ;
width : 136 rpx ;
height : 33 rpx ;
margin - top : 10 rpx ;
background : linear - gradient ( 90 deg , $bg - star 0 % , $bg - end 100 % ) ;
border - radius : 17 px ;
font - size : 22 rpx ;
color : # fff ;
}
}
}
. more - box {
flex - shrink : 0 ;
display : flex ;
flex - direction : column ;
align - items : center ;
justify - content : center ;
width : 80 rpx ;
background - color : # fff ;
border - radius : 16 rpx ;
image {
width : 24 rpx ;
height : 24 rpx ;
margin - top : 10 rpx ;
}
. txt {
display : block ;
writing - mode : vertical - lr ;
font - size : 26 rpx ;
line - height : 1.2 ;
}
}
}
}
. group - wrapper {
padding : 26 rpx 20 rpx ;
margin - top : 20 rpx ;
background : # fff ;
border - radius : 24 rpx ;
. hd {
display : flex ;
align - items : center ;
justify - content : space - between ;
. left {
display : flex ;
align - items : center ;
. icon {
width : 38 rpx ;
height : 38 rpx ;
margin - right : 8 rpx ;
}
. title {
width : 134 rpx ;
height : 33 rpx ;
}
. person {
display : flex ;
align - items : center ;
margin - left : 40 rpx ;
. avatar - box {
display : flex ;
align - items : center ;
image {
width : 30 rpx ;
height : 30 rpx ;
border - radius : 50 % ;
margin - right : - 10 rpx ;
}
}
. num {
margin - left : 18 rpx ;
font - size : 26 rpx ;
color : # 999999 ;
}
}
}
. more {
font - size : 26 rpx ;
color : # 999 ;
. iconfont {
margin - left : 6 rpx ;
font - size : 25 rpx ;
}
}
}
. group - scroll {
width : 100 % ;
margin - top : 25 rpx ;
. group - item {
display : inline - block ;
width : 222 rpx ;
margin - right : 20 rpx ;
box - shadow : 0 px 2 px 6 px 2 px rgba ( 0 , 0 , 0 , 0.03 ) ;
border - radius : 16 rpx ;
image {
width : 100 % ;
height : 222 rpx ;
border - radius : 16 rpx 16 rpx 0 0 ;
}
. info {
padding : 8 rpx 13 rpx ;
. name {
font - size : 24 rpx ;
}
. price - box {
display : flex ;
align - items : center ;
margin - top : 10 rpx ;
. tips {
display : flex ;
align - items : center ;
justify - content : center ;
width : 76 rpx ;
height : 30 rpx ;
margin - right : 6 rpx ;
background : linear - gradient ( 90 deg , rgba ( 255 , 0 , 0 , .1 ) 0 % , rgba ( 255 , 84 , 0 , .1 ) 100 % ) ;
border - radius : 2 px ;
font - size : 20 rpx ;
color : $theme - color ;
}
. price {
font - size : 26 rpx ;
color : $theme - color ;
font - weight : 700 ;
text {
font - size : 20 rpx ;
}
}
}
}
. bom - btn {
display : flex ;
align - items : center ;
justify - content : center ;
width : 100 % ;
height : 48 rpx ;
background : linear - gradient ( 90 deg , $bg - star 0 % , $bg - end 100 % ) ;
border - radius : 0 px 0 px 16 rpx 16 rpx ;
color : # fff ;
}
}
}
}
. boutique {
margin - top : 20 rpx ;
swiper ,
swiper - item ,
. slide - image {
width : 100 % ;
height : 240 rpx ;
border - radius : 12 rpx ;
}
}
. index - product - wrapper {
margin - top : 40 rpx ;
. nav - bd {
display : flex ;
align - items : center ;
. item {
display : flex ;
flex - direction : column ;
align - items : center ;
justify - content : center ;
width : 25 % ;
. txt {
font - size : 32 rpx ;
color : # 282828 ;
}
. label {
display : flex ;
align - items : center ;
justify - content : center ;
width : 124 rpx ;
height : 32 rpx ;
margin - top : 5 rpx ;
font - size : 24 rpx ;
color : # 999 ;
}
& . active {
color : $theme - color ;
. label {
background : linear - gradient ( 90 deg , $bg - star 0 % , $bg - end 100 % ) ;
border - radius : 16 rpx ;
color : # fff ;
}
}
}
}
. list - box {
display : flex ;
flex - wrap : wrap ;
justify - content : space - between ;
margin - top : 30 rpx ;
. item {
width : 345 rpx ;
margin - bottom : 20 rpx ;
background - color : # fff ;
border - radius : 10 px ;
overflow : hidden ;
image {
width : 100 % ;
height : 345 rpx ;
}
. text - info {
padding : 10 rpx 20 rpx 15 rpx ;
. title {
color : # 222222 ;
}
. old - price {
margin - top : 8 rpx ;
font - size : 26 rpx ;
color : # AAAAAA ;
text - decoration : line - through ;
text {
margin - right : 2 px ;
font - size : 20 rpx ;
}
}
. price {
display : flex ;
align - items : flex - end ;
color : $theme - color ;
font - size : 34 rpx ;
font - weight : 800 ;
text {
padding - bottom : 4 rpx ;
font - size : 24 rpx ;
font - weight : normal ;
}
. txt {
display : flex ;
align - items : center ;
justify - content : center ;
width : 28 rpx ;
height : 28 rpx ;
margin - left : 15 rpx ;
margin - bottom : 10 rpx ;
border : 1 px solid $theme - color ;
border - radius : 4 rpx ;
font - size : 22 rpx ;
font - weight : normal ;
}
}
}
}
& . on {
display : flex ;
}
}
}
}
}
. productList {
background - color : # fff ;
}
. productList . list {
padding : 0 20 rpx ;
}
. productList . list . on {
background - color : # fff ;
border - top : 1 px solid # f6f6f6 ;
}
. productList . list . item {
width : 345 rpx ;
margin - top : 20 rpx ;
background - color : # fff ;
border - radius : 10 rpx ;
}
. productList . list . item . on {
width : 100 % ;
display : flex ;
border - bottom : 1 rpx solid # f6f6f6 ;
padding : 30 rpx 0 ;
margin : 0 ;
}
. productList . list . item . pictrue {
position : relative ;
width : 100 % ;
height : 345 rpx ;
}
. productList . list . item . pictrue . on {
width : 180 rpx ;
height : 180 rpx ;
}
. productList . list . item . pictrue image {
width : 100 % ;
height : 100 % ;
border - radius : 20 rpx 20 rpx 0 0 ;
}
. productList . list . item . pictrue image . on {
border - radius : 6 rpx ;
}
. productList . list . item . text {
padding : 20 rpx 17 rpx 26 rpx 17 rpx ;
font - size : 30 rpx ;
color : # 222 ;
}
. productList . list . item . text . on {
width : 508 rpx ;
padding : 0 0 0 22 rpx ;
}
. productList . list . item . text . money {
font - size : 26 rpx ;
font - weight : bold ;
margin - top : 8 rpx ;
}
. productList . list . item . text . money . on {
margin - top : 50 rpx ;
}
. productList . list . item . text . money . num {
font - size : 34 rpx ;
}
. productList . list . item . text . vip {
font - size : 22 rpx ;
color : # aaa ;
margin - top : 7 rpx ;
}
. productList . list . item . text . vip . on {
margin - top : 12 rpx ;
}
. productList . list . item . text . vip . vip - money {
font - size : 24 rpx ;
color : # 282828 ;
font - weight : bold ;
}
. productList . list . item . text . vip . vip - money image {
width : 46 rpx ;
height : 21 rpx ;
margin - left : 4 rpx ;
}
. pictrue {
position : relative ;
}
. fixed {
z - index : 100 ;
position : fixed ;
left : 0 ;
top : 0 ;
background : linear - gradient ( 90 deg , red 50 % , # ff5400 100 % ) ;
}
. mores - txt {
width : 100 % ;
align - items : center ;
justify - content : center ;
height : 70 rpx ;
color : # 999 ;
font - size : 24 rpx ;
. iconfont {
margin - top : 2 rpx ;
font - size : 20 rpx ;
}
}
. menu - txt {
font - size : 24 rpx ;
color : # 454545 ;
}
. mp - bg {
position : absolute ;
left : 0 ;
top : 0 ;
width : 100 % ;
height : 330 rpx ;
background : linear - gradient ( 90 deg , $bg - star 50 % , $bg - end 100 % ) ;
// border-radius: 0 0 30rpx 30rpx;
}
< / style >