< template >
< view class = "page_count" >
< view class = "bg-img" >
< img :src ="bgColor" alt = "" >
< / view >
<!-- 搜索 -- >
< view :class ="{scrolled:isScrolled}" class = "my-main" >
<!-- # ifdef H5 -- >
< view >
< view class = "header" >
< view class = "sys-head tui-skeleton" : style = "{ height: statusBarHeight }" > < / view >
< view class = "serch-box tui-skeleton" >
< view class = "serch-wrapper flex" >
< view v-if ="logoConfig || site_logo" class="logo skeleton-rect"><image :src="logoConfig || site_logo" mode="widthFix" > < / image > < / view >
< navigator v -if = " hotWords.length > 0 " :url=" '/pages/columnGoods/goods_search/index?searchVal=' + searchVal " :class=" ( logoConfig || site _logo ) ? 'input' : 'uninput' "
hover - class = "none" class = "skeleton-rect box" >
< view class = 'swiperTxt' >
< swiper :indicator-dots ="indicatorDots" :autoplay ="autoplay" :interval ="interval" :duration ="duration" vertical = "true"
circular = "true" @ change = "textChange" >
< block v -for = " ( item , index ) in hotWords " : key = 'index' >
< swiper -item catchtouchmove = 'catchTouchMove' >
< view class = 'acea-row row-between-wrapper' >
< view class = 'text acea-row row-between-wrapper' >
< view class = 'newsTitle line1' > { { item . val } } < / view >
< / view >
< / view >
< / s w i p e r - i t e m >
< / block >
< / swiper >
< / view >
< text class = "iconfont icon-xiazai5" > < / text >
< / navigator >
< navigator v -else url = "/pages/columnGoods/goods_search/index" : class = "(logoConfig || site_logo) ? 'input' : 'uninput'"
hover - class = "none" class = "skeleton-rect" >
搜索商品
< text class = "iconfont icon-xiazai5" > < / text >
< / navigator >
< navigator class = "btn skeleton-rect" url = "/pages/chat/customer_list/index?type=0" hover -class = " none " >
< view class = "iconfont icon-xiaoxi" style = "color:#fff;" > < / view >
< text class = "iconnum" v-if ="userInfo.total_unread" > {{ userInfo.total_unread }} < / text >
< / navigator >
< / view >
< / view >
< / view >
< view :style ="'height:'+isTop+'px'" > < / view >
< / view >
<!-- # endif -- >
<!-- # ifdef MP || APP - PLUS -- >
< view >
< view class = "mp-header" id = "home" >
< view class = "sys-head tui-skeleton" : style = "{ height: statusBarHeight }" > < / view >
< view class = "serch-box tui-skeleton" >
< view class = "serch-wrapper flex" >
< view v-if ="logoConfig || site_logo" class="logo skeleton-rect"><image :src="logoConfig || site_logo" mode="widthFix" > < / image > < / view >
< navigator v -if = " hotWords.length > 0 " :url=" '/pages/columnGoods/goods_search/index?searchVal=' + searchVal " :class=" ( logoConfig || site _logo ) ? 'input' : 'uninput' "
hover - class = "none" class = "skeleton-rect box" >
< view class = 'swiperTxt' >
< swiper :indicator-dots ="indicatorDots" :autoplay ="autoplay" :interval ="interval" :duration ="duration" vertical = "true"
circular = "true" @ change = "textChange" >
< block v -for = " ( item , index ) in hotWords " : key = 'index' >
< swiper -item catchtouchmove = 'catchTouchMove' >
< view class = 'acea-row row-between-wrapper' >
< view class = 'text acea-row row-between-wrapper' >
< view class = 'newsTitle line1' > { { item . val } } < / view >
< / view >
< / view >
< / s w i p e r - i t e m >
< / block >
< / swiper >
< / view >
< text class = "iconfont icon-xiazai5" > < / text >
< / navigator >
< navigator v -else url = "/pages/columnGoods/goods_search/index" : class = "(logoConfig || site_logo) ? 'input' : 'uninput'"
hover - class = "none" class = "skeleton-rect" >
搜索商品
< text class = "iconfont icon-xiazai5" > < / text >
< / navigator >
< / view >
< / view >
< / view >
< view :style ="'height:'+marTop+'px;'" > < / view >
< / view >
<!-- # endif -- >
<!-- 选项卡 -- >
< view style = "visibility: hidden;" : style = "{ height: navHeight + 'px' }" > < / view >
< view class = "navTabBox tabNav" :class ="{bgwhite:isScrolled}" :style ="'top:'+isTop+'px'" >
< view class = "longTab" : style = '"width:"+mainWidth+"px"' >
< scroll -view scroll -x = " true " style = "white-space: nowrap; display: flex;" scroll -with -animation :scroll-left ="tabLeft" show -scrollbar = " true " >
< view class = "longItem" :data-index ="index" :class ="index===tabClick?'click':''" @click ="changeTab(item,index)" v-for ="(item,index) in tabTitle" :key="index" :id="'id'+index" > {{ item.info [ 0 ] .value }} < / view >
< view class = "underlineBox" : style = '"transform:translateX("+isLeft+"px);width:"+isWidth+"px"' >
< view class = "underline" > < / view >
< / view >
< / s c r o l l - v i e w >
< / view >
< / view >
< / view >
<!-- 轮播图 -- >
< view class = "swiperBg" : style = "{ marginTop: swiperTop+'px'}" >
< block >
< view class = "swiper page_swiper"
v - if = "imgUrls.length" >
< swiper
: autoplay = "true"
: circular = "circular"
: interval = "intervals"
: duration = "duration"
indicator - color = "rgba(255,255,255,0.6)"
indicator - active - color = "#fff"
: current = "swiperCur"
previous - margin = "30rpx"
next - margin = "30rpx"
@ change = "swiperChange"
: class = "{ scalex:isScale }"
>
< block v-for ="(item,index) in imgUrls" :key ="index" >
< swiper -item : class = "{ active: index == swiperCur,scalex:isScale }" >
< view @click ="goDetail(item)" class = 'slide-navigator acea-row row-between-wrapper' >
< image :src ="item.img" class = "slide-image aa" > < / image >
< / view >
< / s w i p e r - i t e m >
< / block >
< / swiper >
< view class = "dots" >
< block v-for ="(item,index) in imgUrls" :key ="index" >
< view class = "dot" : class = "index == swiperCur ? ' active' : ''" > < / view >
< / block >
< / view >
< / view >
< / block >
< / view >
< / view >
< / template >
< script >
let statusBarHeight = uni . getSystemInfoSync ( ) . statusBarHeight + 'px' ;
import { configMap } from '@/utils' ;
export default {
name : 'homeComb' ,
props : {
dataConfig : {
type : Object ,
default : ( ) => { }
} ,
isScrolled : {
type : Boolean ,
default : false
} ,
isScale : {
type : Boolean ,
default : false
} ,
isMenu : {
type : Boolean ,
default : false
} ,
userInfo : {
type : Object ,
default : ( ) => { }
} ,
} ,
computed : configMap ( { site _logo : '' } ) ,
data ( ) {
return {
statusBarHeight : statusBarHeight ,
scrollHeight : 0 ,
autoplay : true ,
interval : this . dataConfig . titleConfig . value * 1000 || 2500 ,
duration : 500 ,
marTop : 50 ,
searchH : 0 ,
logoConfig : this . dataConfig . logoConfig . url ,
hotWords : this . dataConfig . hotWords . list || [ ] ,
tabClick : 0 , //导航栏被点击
isLeft : 0 , //导航栏下划线位置
isWidth : 0 , //每个导航栏占位
mainWidth : 0 ,
tabLeft : 0 ,
swiperIndex : 0 ,
childIndex : 0 ,
childID : 0 ,
tabTitle : this . dataConfig . listConfig . list ,
fixedTop : 0 ,
isTop : 0 ,
navHeight : 38 ,
homeTop : 20 ,
indicatorDots : false ,
circular : true ,
autoplay : true ,
intervals : 3000 ,
duration : 500 ,
imgUrls : [ ] , //图片轮播数据
imageH : 310 ,
swiperCur : 0 ,
swiperType : 1 ,
searchVal : this . dataConfig . hotWords && this . dataConfig . hotWords . list [ 0 ] [ 'val' ] || '' ,
bgColor : this . dataConfig . swiperConfig . list && this . dataConfig . swiperConfig . list [ 0 ] [ 'img' ] ,
tabId : false ,
isCategory : false ,
swiperTop : 0 ,
isFixed : true ,
} ;
} ,
watch : {
imageH ( nVal , oVal ) {
let self = this
this . imageH = nVal
} ,
} ,
created ( ) {
var that = this
// 获取设备宽度
uni . getSystemInfo ( {
success ( e ) {
that . mainWidth = e . windowWidth
that . isWidth = ( e . windowWidth - 65 ) / 8
}
} )
setTimeout ( ( e ) => {
const query = uni . createSelectorQuery ( ) . in ( this ) ;
query . select ( '.navTabBox' ) . boundingClientRect ( data => {
// that.navHeight = data.height
that . navHeight = data . height > 42 ? data . height : 42
} ) . exec ( ) ;
// #ifdef H5
query . select ( '.header' ) . boundingClientRect ( data => {
that . isTop = data . height
that . marTop = data . height
} ) . exec ( ) ;
// #endif
// #ifdef MP || APP-PLUS
// #ifdef APP-PLUS
const menuButton = 0
//#endif
// #ifdef MP
const menuButton = uni . getMenuButtonBoundingClientRect ( ) ;
//#endif
query
. select ( '.mp-header' )
. boundingClientRect ( data => {
this . homeTop = menuButton . top * 2 + menuButton . height - data . height ;
this . marTop = data . height
} ) . exec ( ) ;
//#endif
} , 100 )
that . isTop = ( uni . getSystemInfoSync ( ) . statusBarHeight + 43 )
that . imgUrls = that . dataConfig . swiperConfig . list
that . $nextTick ( function ( ) {
setTimeout ( ( e ) => {
// #ifdef H5
that . swiperTop = that . navHeight + that . marTop + ( uni . getSystemInfoSync ( ) . statusBarHeight )
//#endif
// #ifdef MP
that . swiperTop = that . navHeight + that . marTop
// that.swiperTop = that.navHeight + that.marTop + 20
//#endif
// #ifdef APP-PLUS
that . swiperTop = uni . getSystemInfoSync ( ) . statusBarHeight + 50 + 30
//#endif
} , 500 )
} )
} ,
mounted ( ) {
let that = this ;
if ( that . tabTitle [ 0 ] [ 'value' ] != '推荐' ) {
that . tabTitle . unshift ( {
img : '' ,
info : [ { value : "推荐" } , { value : false } ]
} )
}
that . $nextTick ( function ( ) {
uni . getImageInfo ( {
src : that . setDomain ( that . imgUrls [ 0 ] . img ) ,
success : function ( res ) {
that . $set ( that , 'imageH' , res . height ) ;
} ,
fail : function ( error ) {
that . $set ( that , 'imageH' , 310 ) ;
console . log ( error , 'error' )
}
} )
} )
} ,
methods : {
goDetail ( url ) {
let urls = url . info [ 1 ] . value
if ( urls . indexOf ( "http" ) != - 1 ) {
// #ifdef H5
location . href = urls
// #endif
} else {
if ( [ '/pages/goods_cate/goods_cate' , '/pages/order_addcart/order_addcart' , '/pages/user/index' , '/pages/plant_grass/index' ] . indexOf ( urls ) == - 1 ) {
uni . navigateTo ( {
url : urls
} )
} else {
uni . switchTab ( {
url : urls
} )
}
}
} ,
//替换安全域名
setDomain : function ( url ) {
url = url ? url . toString ( ) : '' ;
//本地调试打开,生产请注销
if ( url . indexOf ( "https://" ) > - 1 ) return url ;
else return url . replace ( 'http://' , 'https://' ) ;
} ,
swiperChange ( e ) {
let { current , source } = e . detail ;
if ( source === 'autoplay' || source === 'touch' ) {
this . swiperCur = e . detail . current ;
this . bgColor = this . imgUrls [ e . detail . current ] [ 'img' ]
}
} ,
textChange ( e ) {
let { current , source } = e . detail ;
if ( source === 'autoplay' || source === 'touch' ) {
this . searchVal = this . hotWords [ e . detail . current ] [ 'val' ]
}
} ,
/**显示全部分类*/
showCategory ( ) {
this . isCategory = true ;
} ,
/*跳转为页面*/
changeTab ( item , index ) {
if ( this . tabClick == index ) return
this . tabClick = index //设置导航点击了哪一个
this . isLeft = index * this . isWidth + 16 //设置下划线位置
this . tabId = item . info [ 1 ] . value
this . bgColor = this . tabId ? item . img : this . dataConfig . swiperConfig . list [ 0 ] [ 'img' ]
this . imgUrls = this . tabId ? [ { img : item . img } ] : this . dataConfig . swiperConfig . list
this . $emit ( 'changeDiy' , this . tabId ) ;
}
} ,
}
< / script >
< style lang = "scss" scoped >
. header . serch - wrapper . logo {
display : none ;
}
. page _count {
position : relative ;
overflow : hidden ;
. bg - img {
position : absolute ;
width : 100 % ;
height : 100 % ;
top : 0 ;
/* #ifdef MP || APP-PLUS */
z - index : - 1 ;
/* #endif */
/* #ifdef H5 */
z - index : 0 ;
/* #endif */
z - index : 0 ;
filter : blur ( 0 ) ;
overflow : hidden ;
img {
width : 100 % ;
height : 100 % ;
filter : blur ( 30 rpx ) ;
transform : scale ( 1.5 ) ;
}
}
}
. my - main {
transition : background - color .5 s ease ;
}
. swiperTxt {
width : 300 rpx ;
line - height : 64 rpx ;
height : 64 rpx ;
overflow : hidden ;
}
. swiperTxt . text {
width : 480 rpx ;
}
. swiperTxt . text . newsTitle {
width : 300 rpx ;
font - size : 24 rpx ;
color : # ffffff ;
}
. swiperTxt swiper {
height : 100 % ;
}
. header {
z - index : 99 ;
position : fixed ;
left : 0 ;
width : 100 % ;
. btn {
position : relative ;
margin - left : 30 rpx ;
. iconfont {
font - size : 45 rpx ;
}
}
. iconnum {
min - width : 14 rpx ;
color : # E93323 ;
background : # fff ;
border - radius : 15 rpx ;
position : absolute ;
right : - 10 rpx ;
top : - 10 rpx ;
font - size : 10 px ;
padding : 0 5 px ;
}
. serch - wrapper {
align - items : center ;
padding : 20 rpx 30 rpx 20 rpx 30 rpx ;
. logo {
width : 133 rpx ;
margin - right : 20 rpx ;
}
image {
width : 133 rpx ;
height : 66 rpx ;
}
. box {
flex : 1 ;
}
. input , . uninput {
line - height : 64 rpx ;
height : 64 rpx ;
padding : 0 0 0 30 rpx ;
background : rgba ( 0 , 0 , 0 , .2 ) ;
color : # fff ;
border - radius : 30 rpx ;
font - size : 28 rpx ;
z - index : 2 ;
position : relative ;
box - sizing : border - box ;
. iconfont {
position : absolute ;
right : 20 rpx ;
top : 0 ;
color : # eeeeee ;
}
}
}
}
. mp - header {
z - index : 99 ;
position : fixed ;
left : 0 ;
width : 100 % ;
. box {
flex : 1 ;
}
. serch - wrapper {
display : flex ;
align - items : center ;
padding : 0 50 rpx 0 30 rpx ;
height : 76 rpx ;
. logo {
width : 133 rpx ;
margin - right : 20 rpx ;
line - height : 0 ;
}
image {
width : 118 rpx ;
height : 42 rpx ;
}
. input , . uninput {
display : flex ;
/* #ifdef MP */
flex : 0 ;
/* #endif */
/* #ifdef APP-PLUS */
flex : 1 ;
/* #endif */
flex : 1 ;
align - items : center ;
height : 64 rpx ;
line - height : 64 rpx ;
padding : 0 50 rpx 0 30 rpx ;
background : rgba ( 0 , 0 , 0 , .2 ) ;
border - radius : 100 rpx ;
color : # ffffff ;
font - size : 28 rpx ;
position : relative ;
box - sizing : border - box ;
. iconfont {
position : absolute ;
right : 20 rpx ;
top : 0 ;
color : # eeeeee ;
}
}
/* #ifdef MP */
. uninput {
max - width : 500 rpx ;
}
. input {
max - width : 340 rpx ;
}
/* #endif */
}
}
. tabNav {
padding - top : 10 rpx ;
}
. navTabBox {
color : rgba ( 255 , 255 , 255 , 1 ) ;
padding : 0 30 rpx ;
z - index : 10 ;
left : 0 ;
width : 100 % ;
box - sizing : border - box ;
position : fixed ;
& . isFixed {
z - index : 30 ;
position : fixed ;
left : 0 ;
width : 100 % ;
/* #ifdef H5 */
top : 0 ;
/* #endif */
}
scroll - view {
width : 100 % ;
padding - right : 30 rpx ;
height : 70 rpx ;
}
. click {
color : white ;
}
. longTab {
. longItem {
height : 50 upx ;
display : inline - block ;
line - height : 50 upx ;
text - align : center ;
font - size : 28 rpx ;
color : # FFFFFF ;
max - width : 160 rpx ;
margin - right : 30 rpx ;
position : relative ;
& : last - child {
margin - right : 0 ;
}
& . click {
font - weight : bold ;
font - size : 30 rpx ;
color : # FFFFFF ;
& : : after {
content : '' ;
transition : .5 s ;
width : 33 rpx ;
height : 4 rpx ;
background : # FFFFFF ;
position : absolute ;
bottom : - 4 rpx ;
left : 50 % ;
margin - left : - 16 rpx ;
}
}
}
}
}
. scrolled {
z - index : 5000 ;
position : fixed ;
min - height : 180 rpx ;
left : 0 ;
top : 0 ;
width : 100 % ;
background : # fff ! important ;
transition : background - color .5 s ease ;
. longItem , . click , . category text {
color : # 000000 ! important ;
}
. navTabBox , . mp - header {
transition : background - color .5 s ease ;
}
. btn . iconfont {
color : # 333333 ! important ;
}
. iconnum {
background : # 333333 ! important ;
}
. underline {
background : # 000000 ! important ;
}
. click {
& : : after {
background - color : # fff ! important ;
}
}
}
. swiperBg {
z - index : 1 ;
margin - top : 10 rpx ;
padding - bottom : 30 rpx ;
. colorBg {
position : absolute ;
left : 0 ;
top : 0 ;
height : 130 rpx ;
width : 100 % ;
}
. page _swiper {
position : relative ;
width : 100 % ;
height : auto ;
margin : 0 auto ;
border - radius : 10 rpx ;
overflow - x : hidden ;
z - index : 8 ;
padding : 0 10 rpx ;
swiper - item {
border - radius : 10 rpx ;
}
. swiper - item , image , . acea - row . row - between - wrapper {
width : 100 % ;
height : 100 % ;
margin : 0 auto ;
border - radius : 10 rpx ;
}
swiper {
width : 100 % ;
display : block ;
height : 308 rpx ;
& . scalex {
/deep/ . uni - swiper - slide - frame {
transform : translate ( 0 , 0 ) ! important ;
}
}
}
image {
transform : scale ( 0.93 ) ;
transition : all 0.6 s ease ;
}
swiper - item . active , swiper - item . scalex {
image {
transform : scale ( 1 ) ;
}
}
/*用来包裹所有的小圆点 */
. dots {
width : 156 rpx ;
height : 36 rpx ;
display : flex ;
flex - direction : row ;
position : absolute ;
left : 320 rpx ;
bottom : 0 ;
}
/*未选中时的小圆点样式 */
. dot {
width : 16 rpx ;
height : 6 rpx ;
border - radius : 6 rpx ;
margin - right : 6 rpx ;
background - color : rgba ( 255 , 255 , 255 , .4 ) ;
/*选中以后的小圆点样式 */
& . active {
width : 32 rpx ;
height : 6 rpx ;
background - color : rgba ( 255 , 255 , 255 , .4 ) ;
}
}
}
}
/deep/ . dot0 . uni - swiper - dots - horizontal {
left : 10 % ;
}
/deep/ . dot1 . uni - swiper - dots - horizontal {
left : 50 % ;
}
/deep/ . dot2 . uni - swiper - dots - horizontal {
left : 90 % ;
}
< / style >