在網上查了不少問題,緣由應該是加載順序的問題,數據尚未徹底加載的時候就已經渲染swiper了。css
解決辦法,在swiper初始化的時候把如下兩個屬性加上。vue
observer:true,//修改swiper本身或子元素時,自動初始化swiper observeParents:true,//修改swiper的父元素時,自動初始化swiper
就能夠了。web
下面貼完整代碼,有興趣的能夠看一下。vuex
<template> <div class="main_box"> <swiper :options="swiperOptionTwo" ref="mySwiper"> <!-- slides --> <swiper-slide> <div id="index-page"> <img class="index-bg" src="../assets/images/index_bg.png"> <img class="share-button" src="../assets/images/shoes.png" v-on:click="toShoes"> <router-link to="/rule"><div class="rule-click div-click"></div></router-link> <swiper :options="swiperOption" ref="mySwiper"> <!-- slides --> <swiper-slide> <div v-for="(value,index) in marathonList" class="main-info"> <div class="marathon-box"> <img @click="goTms(value.coverLink)" class="index-click" src="../assets/images/index-click-img_03.png"> <div class="box-info"> <div v-for="(valueMode,index) in value.marathonList" class="box-info-line"> <p class="info-text"><span>{{valueMode.name}}</span><span class="value"> {{valueMode.count}}</span></p> <img class="heart" src="../assets/images/heart.png"> <p class="info-text"><span>{{valueMode.consume}}</span>人已申請</p> </div> <div class="box-info-line"> <p class="info-text bottomFont"><span>申請時間</span><span class="value bottomFont"> {{value.applyTime}}</span></p> <p class="info-text bottomFont"><span>開獎時間</span><span class="value bottomFont"> {{ value.luckTime | moment("MMM Do YY") }}</span></p> </div> </div> </div> <button class="white-button" v-if="value.applyStatus == 0" @click="goApply(value.name)">當即申請</button> <button class="white-button" v-if="value.applyStatus == 1">坐等開獎</button> <button class="white-button" v-on:click="luck(value.name)" v-if="true">點擊開獎</button> <button class="white-button" v-if="value.applyStatus == 4">未中獎</button> <button class="white-button" v-if="value.applyStatus == 3">中獎</button> <button class="white-button" v-if="value.applyStatus == 5">已結束</button> </div> </swiper-slide> <swiper-slide> <div class="main-info"> <div v-for="(value,index) in marathonList" class="marathon-box"> <img v-on:click="goTms" class="index-click" src="../assets/images/index-click-img_03.png"> <div class="box-info"> <div v-for="(valueMode,index) in value.marathonList" class="box-info-line"> <p class="info-text"><span>{{valueMode.name}}</span><span class="value"> {{valueMode.count}}</span></p> <img class="heart" src="../assets/images/heart.png"> <p class="info-text"><span>{{valueMode.consume}}</span>人已申請</p> </div> <div class="box-info-line"> <p class="info-text bottomFont"><span>申請時間</span><span class="value bottomFont"> {{value.applyTime}}</span></p> <p class="info-text bottomFont"><span>開獎時間</span><span class="value bottomFont"> {{ value.luckTime | moment("MMM Do YY") }}</span></p> </div> </div> </div> </div> </swiper-slide> <div class="swiper-pagination" slot="pagination"></div> <div class="swiper-button-prev" slot="button-prev"></div> <div class="swiper-button-next" slot="button-next"></div> </swiper> </div> </swiper-slide> <swiper-slide> <!--slide2--> <div class="slideTwo"> <!-- <img class="index-bg" src="../assets/images/bottom_bg.png"> --> <div class="bottom-top"> <p>跑馬訓練計劃</p> <img src="../assets/images/card_test.png"> <img src="../assets/images/card_top.png"> </div> <div class="bottom-mid"> <p>跑馬乾貨</p> <img src="../assets/images/card_test.png"> <img src="../assets/images/card_mid.png"> </div> <div class="bottom-bot"> <p>咕咚學院</p> <img src="../assets/images/card_test.png"> <img src="../assets/images/card_bottom.png"> </div> </div> </swiper-slide> </swiper> <img src="../assets/images/tip.png" style="width: 110px; height: 59px; margin-bottom: 5px; left: 320px;" id="array" class="fixed"> </div> </template> <style rel="stylesheet/scss" lang="scss" scoped> #index-page { position: relative; .swiper-container { position: absolute; height: 1003px; width: 100%; top: 200px; } .swiper-button-next { background-image: url(../assets/images/next-btn.png);width: 25px; height: 635px; right: 0px; background-size: cover; top: 15%; } } .swiper-container { position: absolute; height: 1217px; width: 100%; } .slideTwo { height: 1217px; color: #fff; p { position: absolute; margin-top: 60px; margin-left: 23px; color: #b8b8b8; font-size: 24px; } img { position: absolute; margin-top: 100px; left: 21px; display: block; } .bottom-top { position: relative; height: 400px; } .bottom-mid { position: relative; height: 400px; } .bottom-bot { position: relative; height: 400px; } } .swiper-button-prev { background-image: url(../assets/images/next-btn.png); height: 635px; left: 0px; background-size: cover; top: 15%; } @-webkit-keyframes tipmove{0%{bottom:10px;opacity:0}50%{bottom:15px;opacity:1}100%{bottom:20px;opacity:0}} .ani{ position:absolute; } #array{ -webkit-animation: tipmove 1.5s infinite ease-in-out; } .fixed{ position:absolute; z-index:999; width: 125px; height: 70px; margin-bottom: 13px; left: 320px; } .share-button { position: absolute; top: 0px; right: 20px; } .rule-click { position: absolute; top: 20px; left: 40px; width: 150px; height: 60px; } .text-link { margin-top: 40px; text-decoration: underline; color: #858585; font-size: 28px; } .bottomFont { font-size: 20px !important; } .white-button { display: block; margin-top: 70px; background-color: #ffffff; color: #000000; padding: 20px; width: 400px; border-radius: 40px; margin-left: 135px; font-weight: 400; } .main-info { position: absolute; top: 100px; width: 670px; left: 50%; transform: translate3D(-50%, 0, 0); -webkit-transform: translate3D(-50%, 0, 0); .marathon-box { background-color: #ffffff; color: #a2a2a2; font-size: 28px; .box-info { padding: 0 50px 40px 50px; } .box-info-line { text-align: left; .info-text { display: inline-block; padding: 40px 0px 0px 0px; min-width: 240px; } } .index-click { display: block; } .value { font-size: 29px; color: #292929; } } } .index-bg { position: relative; display: block; } </style> <script type="text/ecmascript-6"> import store from '../store/index'; import api from '../assets/script/api'; import codoonNativeBridge from 'codoon-native-bridge-js' import { swiper, swiperSlide } from 'vue-awesome-swiper' import {mapGetters} from 'vuex'; import moment from 'vue-moment' export default{ components: { swiper, swiperSlide }, data(){ return { progress: 0, temp: 0, store: store, isInCodoon: false, swiperOption: { slidesPerView: 'auto', centeredSlides: true, paginationClickable: true, spaceBetween: 30, prevButton: '.swiper-button-prev', nextButton: '.swiper-button-next', loop: true, notNextTick: true, observer:true,//修改swiper本身或子元素時,自動初始化swiper observeParents:true,//修改swiper的父元素時,自動初始化swiper }, swiperOptionTwo: { direction : 'vertical', speed: 800, slidesPerView: 'auto', centeredSlides: true, paginationClickable: true, spaceBetween: 30, notNextTick: true, observer:true,//修改swiper本身或子元素時,自動初始化swiper observeParents:true,//修改swiper的父元素時,自動初始化swiper }, swiperIndex: 0, marathonList: [], share: this.$route.query.share, } }, computed: { // swiper() { // return this.$refs.mySwiper.swiper; // } }, mounted() { var vm = this; api.marathonList({}).then(response => { if(response.status) { vm.marathonList = response.data.marathonList; } }); // this.$refs.mySwiper.swiper; // this.swiper(); }, computed: { ...mapGetters([ 'userInfo' ]) }, methods: { swiper() { return this.$refs.mySwiper.swiper; }, goTms(url) { var nativeB = new codoonNativeBridge(); nativeB.jumpNative({ type: 'webView', value: url }); }, toShoes() { store.router.push({name: 'shoes'}); }, luck(name) { store.router.push({name: 'luck', query: {name: name}}); }, goApply(name) { store.router.push({name: 'select', query: { type: this.type, name: name }}); } } } </script>