You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
173 lines
4.0 KiB
173 lines
4.0 KiB
5 months ago
|
<template>
|
||
|
<view class="swiperBg">
|
||
|
<view class='boutique' :class="{'off': sty ==='off'}" v-if="isShow && bastBanner.length && !isIframe">
|
||
|
<swiper autoplay="true" indicator-dots="true" :circular="circular" :interval="interval" :duration="duration"
|
||
|
indicator-color="rgba(255,255,255,0.6)" indicator-active-color="#fff" :style="'height:'+ (imageH) +'rpx;'">
|
||
|
<block v-for="(item,index) in bastBanner">
|
||
|
<swiper-item :key='index'>
|
||
|
<view style='width:100%;height:100%;' hover-class='none' @click="goDetail(item)">
|
||
|
<image :src="item.img" class="slide-image" :style="'height:'+ (imageH) +'rpx;'" />
|
||
|
</view>
|
||
|
</swiper-item>
|
||
|
</block>
|
||
|
</swiper>
|
||
|
</view>
|
||
|
<view class='boutique' :style="'height:'+ (imageH) +'rpx;'" v-if="bastBanner.length && isIframe">
|
||
|
<swiper autoplay="true" indicator-dots="true" :style="'height:'+ (imageH) +'rpx;'" :circular="circular" :interval="interval" :duration="duration"
|
||
|
indicator-color="rgba(255,255,255,0.6)" indicator-active-color="#fff">
|
||
|
<block v-for="(item,index) in bastBanner">
|
||
|
<swiper-item :key='index'>
|
||
|
<view style='width:100%;height:100%;' hover-class='none' @click="goDetail(item)">
|
||
|
<image :src="item.img" class="slide-image" :style="'height:'+ (imageH) +'rpx;'"/>
|
||
|
</view>
|
||
|
</swiper-item>
|
||
|
</block>
|
||
|
</swiper>
|
||
|
</view>
|
||
|
<block v-if="isIframe && !bastBanner.length">
|
||
|
<view class="empty-img">{{$t(`暂无图片,请上传图片`)}}</view>
|
||
|
</block>
|
||
|
</view>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
let app = getApp()
|
||
|
import {
|
||
|
goPage
|
||
|
} from '@/libs/order.js'
|
||
|
export default {
|
||
|
name: 'swiperBg',
|
||
|
props: {
|
||
|
dataConfig: {
|
||
|
type: Object,
|
||
|
default: () => {}
|
||
|
},
|
||
|
sty: {
|
||
|
type: String,
|
||
|
default: 'on'
|
||
|
}
|
||
|
},
|
||
|
data() {
|
||
|
return {
|
||
|
indicatorDots: false,
|
||
|
circular: true,
|
||
|
autoplay: true,
|
||
|
interval: 3000,
|
||
|
duration: 500,
|
||
|
bastBanner: [], //图片轮播数据
|
||
|
name: this.$options.name,
|
||
|
isIframe: false,
|
||
|
isShow: true,
|
||
|
imageH: 375
|
||
|
};
|
||
|
},
|
||
|
watch: {
|
||
|
dataConfig: {
|
||
|
immediate: true,
|
||
|
handler(nVal, oVal) {
|
||
|
if (nVal) {
|
||
|
this.bastBanner = nVal.imgList.list;
|
||
|
this.isShow = nVal.isShow.val;
|
||
|
this.imgUrls = nVal.imgList ? nVal.imgList.list : [];
|
||
|
this.isShow = nVal.isShow ? nVal.isShow.val : true
|
||
|
uni.getImageInfo({
|
||
|
src: this.imgUrls.length ? this.imgUrls[0].img : '',
|
||
|
success: (res) => {
|
||
|
if (res && res.height > 0) {
|
||
|
this.$set(this, 'imageH',
|
||
|
res.height / res
|
||
|
.width * 690)
|
||
|
} else {
|
||
|
this.$set(this, 'imageH', 375);
|
||
|
}
|
||
|
},
|
||
|
fail: (error) => {
|
||
|
this.$set(this, 'imageH', 375);
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
created() {
|
||
|
this.isIframe = app.globalData.isIframe
|
||
|
},
|
||
|
mounted() {},
|
||
|
methods: {
|
||
|
//替换安全域名
|
||
|
setDomain: function(url) {
|
||
|
url = url ? url.toString() : '';
|
||
|
//本地调试打开,生产请注销
|
||
|
if (url.indexOf("https://") > -1) return url;
|
||
|
else return url.replace('http://', 'https://');
|
||
|
},
|
||
|
goDetail(url) {
|
||
|
goPage().then(res => {
|
||
|
this.$util.JumpPath(urls);
|
||
|
})
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<style lang="scss">
|
||
|
.swiperBg {
|
||
|
// background-color: $uni-bg-color;
|
||
|
width: 100%;
|
||
|
}
|
||
|
|
||
|
.empty-img {
|
||
|
width: 690rpx;
|
||
|
// height: 300rpx;
|
||
|
// border-radius: 14rpx;
|
||
|
margin: 26rpx auto 0 auto;
|
||
|
background-color: #ccc;
|
||
|
text-align: center;
|
||
|
line-height: 300rpx;
|
||
|
|
||
|
.iconfont {
|
||
|
font-size: 50rpx;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.boutique {
|
||
|
margin: 0 $uni-index-margin-col;
|
||
|
// width: 711rpx;
|
||
|
// height: 300rpx;
|
||
|
// margin: 0rpx auto 0 auto;
|
||
|
// padding: 28rpx 0;
|
||
|
}
|
||
|
|
||
|
.boutique swiper {
|
||
|
width: 100%;
|
||
|
position: relative;
|
||
|
}
|
||
|
|
||
|
.boutique image {
|
||
|
width: 100%;
|
||
|
border-radius: 10rpx;
|
||
|
}
|
||
|
.off{
|
||
|
padding: 0rpx 20rpx;
|
||
|
background-color: #fff;
|
||
|
}
|
||
|
.off image {
|
||
|
// border-radius: 0 0 10rpx 10rpx;
|
||
|
}
|
||
|
|
||
|
.boutique .wx-swiper-dot {
|
||
|
width: 7rpx;
|
||
|
height: 7rpx;
|
||
|
border-radius: 50%;
|
||
|
}
|
||
|
|
||
|
.boutique .wx-swiper-dot-active {
|
||
|
width: 20rpx;
|
||
|
border-radius: 5rpx;
|
||
|
}
|
||
|
|
||
|
.boutique .wx-swiper-dots.wx-swiper-dots-horizontal {
|
||
|
margin-bottom: -8rpx;
|
||
|
}
|
||
|
</style>
|