<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> </swiper-item> </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> </swiper-item> </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> </scroll-view> </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> </swiper-item> </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> .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(30rpx); transform: scale(1.5); } } } .my-main{ transition: background-color .5s ease; } .swiperTxt { width: 300rpx; line-height: 64rpx; height: 64rpx; overflow: hidden; } .swiperTxt .text { width: 480rpx; } .swiperTxt .text .newsTitle { width: 300rpx; font-size: 24rpx; color: #ffffff; } .swiperTxt swiper { height: 100%; } .header { z-index: 99; position: fixed; left: 0; width: 100%; .btn { position: relative; margin-left: 30rpx; .iconfont { font-size: 45rpx; } } .iconnum { min-width: 14rpx; color: #E93323; background: #fff; border-radius: 15rpx; position: absolute; right: -10rpx; top: -10rpx; font-size: 10px; padding: 0 5px; } .serch-wrapper { align-items: center; padding: 20rpx 30rpx 20rpx 30rpx; .logo { width: 133rpx; margin-right: 20rpx; } image { width: 133rpx; height: 66rpx; } .box{ flex: 1; } .input,.uninput { line-height: 64rpx; height: 64rpx; padding: 0 0 0 30rpx; background: rgba(0,0,0,.2); color: #fff; border-radius: 30rpx; font-size: 28rpx; z-index: 2; position: relative; box-sizing: border-box; .iconfont { position: absolute; right: 20rpx; 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 50rpx 0 30rpx; height: 76rpx; .logo { width: 133rpx; margin-right: 20rpx; line-height: 0; } image { width: 118rpx; height: 42rpx; } .input,.uninput { display: flex; /* #ifdef MP */ flex: 0; /* #endif */ /* #ifdef APP-PLUS */ flex: 1; /* #endif */ flex: 1; align-items: center; height: 64rpx; line-height: 64rpx; padding: 0 50rpx 0 30rpx; background: rgba(0,0,0,.2); border-radius: 100rpx; color: #ffffff; font-size: 28rpx; position: relative; box-sizing: border-box; .iconfont { position: absolute; right: 20rpx; top: 0; color: #eeeeee; } } /* #ifdef MP */ .uninput{ max-width: 500rpx; } .input{ max-width: 340rpx; } /* #endif */ } } .tabNav { padding-top: 10rpx; } .navTabBox { color: rgba(255, 255, 255, 1); padding: 0 30rpx; 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: 30rpx; height: 70rpx; } .click { color: white; } .longTab { .longItem{ height: 50upx; display: inline-block; line-height: 50upx; text-align: center; font-size: 28rpx; color: #FFFFFF; max-width: 160rpx; margin-right: 30rpx; position: relative; &:last-child{ margin-right: 0; } &.click{ font-weight: bold; font-size: 30rpx; color: #FFFFFF; &::after{ content: ''; transition: .5s; width: 33rpx; height: 4rpx; background: #FFFFFF; position: absolute; bottom: -4rpx; left: 50%; margin-left: -16rpx; } } } } } .scrolled{ z-index: 5000; position: fixed; min-height: 180rpx; left: 0; top: 0; width: 100%; background: #fff!important; transition: background-color .5s ease; .longItem,.click,.category text{ color: #000000!important; } .navTabBox,.mp-header{ transition: background-color .5s 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: 10rpx; padding-bottom: 30rpx; .colorBg { position: absolute; left: 0; top: 0; height: 130rpx; width: 100%; } .page_swiper { position: relative; width: 100%; height: auto; margin: 0 auto; border-radius: 10rpx; overflow-x: hidden; z-index: 8; padding: 0 10rpx; swiper-item{ border-radius: 10rpx; } .swiper-item, image, .acea-row.row-between-wrapper { width: 100%; height:100%; margin: 0 auto; border-radius: 10rpx; } swiper{ width: 100%; display: block; height: 308rpx; &.scalex{ /deep/.uni-swiper-slide-frame{ transform: translate(0,0)!important; } } } image { transform: scale(0.93); transition: all 0.6s ease; } swiper-item.active, swiper-item.scalex{ image { transform: scale(1); } } /*用来包裹所有的小圆点 */ .dots { width: 156rpx; height: 36rpx; display: flex; flex-direction: row; position: absolute; left: 320rpx; bottom: 0; } /*未选中时的小圆点样式 */ .dot { width: 16rpx; height: 6rpx; border-radius: 6rpx; margin-right: 6rpx; background-color: rgba(255,255,255,.4); /*选中以后的小圆点样式 */ &.active { width: 32rpx; height: 6rpx; 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>