vue中使用swiper失效问题及解决

 更新时间:2023年01月14日 10:35:13   作者:Li_na_na01  
这篇文章主要介绍了vue中使用swiper失效问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

vue使用swiper失效

问题描述

需求是 要在一个循环的列表中第一组数据后添加一个轮播,效果如下

由于所有循环的数据都是一个接口返回,并在一个数组中。

由以下代码实现

<div v-for="(item, index) in videoList" :key="index">
    <div class="index_list01">
        <div class="index_list">
            <div class="index_list1">
                <div class="index_list1_1">{{item.title}}</div>
                <div class="index_list1_2" @click="gotoPage('/mine/search')">查看更多 ></div>
            </div>
            <div class="index_list2">
            // 此处无关代码省略
            </div>
        </div>
    </div>
    <div v-if="index == 0" class="advert">
        <div class="banner">
            <div class="swiper-container swiper2">
                <div class="swiper-wrapper">
                    <div v-for="(item, index) in advertList" :key="item.id || index" class="swiper-slide"><img :src="item.picUrl"/></div>
                </div>
                <div class="swiper-pagination"></div>
            </div>
        </div>
    </div>
</div>

感觉上没什么问题,到浏览器里发现,其他轮播都可以滑动,唯独这个轮播不行。

排查过后发现,轮播样式生效了,但是swiper自动添加的class没加上,并且不可滑动,也就是说 swiper的js部分没生效

那就是初始化swiper的问题了。我是直接在mounted生命周期里初始化的swiper,问题应该在这里,swiper的初始化在异步加载的数据渲染之前了。

问题解决

// data中添加swiper状态
data(){
	return {
		swiper: ''
	}
}

猜测是swiper的初始化的顺序导致的,那就把初始化的操作延后试一下

// 在methods里定义初始化的方法
initSwiper(){
    if(this.swiper != ''){return}
    this.swiper = new Swiper('.swiper-container', {
        loop: true,
    })
}
getInfo() {
    this.$api.index.getIndexInfo().then(res => {
        let {indexCenterBannerList, classifyListCollect} = res.data
        let videoKeys = Object.keys(classifyListCollect)
        this.advertList = indexCenterBannerList
        this.videoList = videoKeys.map(item =>{
            return {
                title: item,
                list: classifyListCollect[item]
            }
        })
        // 将初始化方法放在数据请求后的下一个dom更新后
        this.$nextTick(()=>{
            this.initSwiper()
        })
    })
}

调整完后,果然swiper正常了。并且之前其他swiper的loop失效的问题也解决了

vue2+swiper踩坑记 effect等参数无效

vue2使用swiper需要安装vue-awesome-swiper,然后坑来了

使用最新4.版本的vue-awesome-swiper,effect等参数无效

解决: 降级到3.1.3

注意: 4.版本引入swiper, swiperSlide是大写 3.1.3是小写

4.版本获取实例this.refs.mySwiper.swiperInstance3.版本获取实例this.refs.mySwiper.swiper

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 关于Vue中img动态拼接src图片地址的问题

    关于Vue中img动态拼接src图片地址的问题

    这篇文章主要介绍了关于Vue中img动态拼接src图片地址的问题,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-10-10
  • Babel自动生成Attribute文档实现详解

    Babel自动生成Attribute文档实现详解

    这篇文章主要为大家介绍了Babel自动生成Attribute文档实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • 一文搞懂vue中provide和inject实现原理对抗平庸

    一文搞懂vue中provide和inject实现原理对抗平庸

    这篇文章主要为大家介绍了vue中provide和inject实现原理的深入理解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • el-popover如何通过js手动控制弹出框显示、隐藏

    el-popover如何通过js手动控制弹出框显示、隐藏

    最近项目中多次用到了Popover弹出框,下面这篇文章主要给大家介绍了关于el-popover如何通过js手动控制弹出框显示、隐藏的相关资料,需要的朋友可以参考下
    2023-12-12
  • vue路由前进后退动画效果的实现代码

    vue路由前进后退动画效果的实现代码

    这篇文章主要介绍了vue路由前进后退动画效果,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-12-12
  • Vue-Element-Admin前端接入SSO的方法步骤

    Vue-Element-Admin前端接入SSO的方法步骤

    本文主要介绍了Vue-Element-Admin前端接入SSO的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • Vue项目保存代码之后页面自动更新问题

    Vue项目保存代码之后页面自动更新问题

    这篇文章主要介绍了Vue项目保存代码之后页面自动更新问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • VUE脚手架具体使用方法

    VUE脚手架具体使用方法

    这篇文章主要介绍了VUE脚手架具体使用方法,vue-cli这个构建工具大大降低了webpack的使用难度,小编觉得不错,下面就一起来了解一下具体使用方法
    2019-05-05
  • 详解webpack + vue + node 打造单页面(入门篇)

    详解webpack + vue + node 打造单页面(入门篇)

    本篇文章主要介绍了详解webpack + vue + node 打造单页面(入门篇) ,非常具有实用价值,需要的朋友可以参考下
    2017-09-09
  • ElementUI如何修改el-cascader的默认样式

    ElementUI如何修改el-cascader的默认样式

    ElementUI 是一套ui组件库,目前最新版本 react 和 vue 等主流框架都有支持。该库默认主题色是天蓝色,若用于项目开发,难免遇到要需求修改其默认样式的情况,这篇文章主要介绍了ElementUI如何修改el-cascader的默认样式,需要的朋友可以参考下
    2023-12-12

最新评论