vue-awesome-swiper的左右切换按钮功能失效问题处理

本文主要是介绍vue-awesome-swiper的左右切换按钮功能失效问题处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 问题描述

      在使用vue-asesome-swiper时,总是出现各种各样的问题,这次出现的问题是,左右切换按钮左右插槽的方式引用时,出现的功能失效的问题。

      引用的方式如下:

// html
<div class="box"><swiper ref="interSwiper" :options="interSwiperOptions"><swiper-slide v-for="(item, index) in data" :key="index"><div>{{item.name}}</div></swiper-slide></swiper><div class="swiper-button-next" slot="button-next"></div><div class="swiper-button-prev" slot="button-prev"></div>
</div>// vue
data () {return {interSwiperOptions: {slidesPerView: 3,loop: false,autoplay: false,allowTouchMove: true,observer: true,observeParents: true,spaceBetween: 0,navigation: {nextEl: '.swiper-button-next',prevEl: '.swiper-button-prev',disabledClass: 'my-button-disabled',}  },}
}

      具体的样式就不写了。出现的问题,引入了左右切换按钮,并且正常显示默认样式,但点击功能失效,并且navigation中的disabledClass也失效了。

      具体导致失效的原因,还没有找到,如果有知道此原因的朋友们,可以留言告诉我,谢谢!虽然没有找到具体原因,但是,我对此问题进行了处理,能够正常使用

2. 关于点击事件失效的解决办法

     在引用时,通过自己给左右切换按钮进行绑定点击事件,实现原本正常使用的功能,具体操作如下:

// html
<div class="swiper-button-next" slot="button-next" @click='swiperNext'></div>
<div class="swiper-button-prev" slot="button-prev" @click='swiperPrev'></div>// vue
methods: {swiperNext() {this.$refs.interSwiper.$swiper.slideNext()},swiperPrev() {this.$refs.interSwiper.$swiper.slidePrev()},
}

3. 关于disabledClass功能失效的处理

      这个问题通过swiper的on监听回调时事件进行处理,对左右切换按钮进行动态绑定和解绑 ' my-button-disabled ' 类名。具体操作方案通过原生js书写。

// vue datainterSwiperOptions: {slidesPerView: 3,loop: false,autoplay: false,allowTouchMove: true,observer: true,observeParents: true,spaceBetween: 0,navigation: {nextEl: '.swiper-button-next',prevEl: '.swiper-button-prev',disabledClass: 'my-button-disabled',},on:{slideChangeTransitionEnd: function () { // 监听slide切换结束后let boxs = Math.ceil(this.slides.length/3) // 确定有几屏let swiper2 = document.getElementsByClassName('box')[0]let nextB = swiper2.getElementsByClassName('swiper-button-next')let prevB = swiper2.getElementsByClassName('swiper-button-prev')nextB[0].setAttribute('class', 'swiper-button-next')prevB[0].setAttribute('class', 'swiper-button-prev')if (this.activeIndex === (boxs-1)) { // 切换结束后,如果为最后一屏next按钮置灰nextB[0].setAttribute('class', 'swiper-button-next my-button-disabled')} if (this.activeIndex === 0) { // 切换结束后,如果为第一屏next按钮置灰prevB[0].setAttribute('class', 'swiper-button-prev my-button-disabled')} },init: function(){ //监听swiper初始化时,对左右按钮样式进行处理let boxs = Math.ceil(this.slides.length/3)let swiper2 = document.getElementsByClassName('box')[0]let nextB = swiper2.getElementsByClassName('swiper-button-next')let prevB = swiper2.getElementsByClassName('swiper-button-prev')nextB[0].setAttribute('class', 'swiper-button-next')// 初始化时,prev按钮是不可点击的,应该置灰prevB[0].setAttribute('class', 'swiper-button-prev my-button-disabled')if (boxs === 1) { // 如果只有一屏,next按钮也要置灰nextB[0].setAttribute('class', 'swiper-button-next my-button-disabled')}}, },}
/* 置灰按钮的样式 */
.my-button-disabled {opacity: 0.5;
}

 

 

 

 

 

 

这篇关于vue-awesome-swiper的左右切换按钮功能失效问题处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/729007

相关文章

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

mysql表操作与查询功能详解

《mysql表操作与查询功能详解》本文系统讲解MySQL表操作与查询,涵盖创建、修改、复制表语法,基本查询结构及WHERE、GROUPBY等子句,本文结合实例代码给大家介绍的非常详细,感兴趣的朋友跟随... 目录01.表的操作1.1表操作概览1.2创建表1.3修改表1.4复制表02.基本查询操作2.1 SE

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

Golang如何用gorm实现分页的功能

《Golang如何用gorm实现分页的功能》:本文主要介绍Golang如何用gorm实现分页的功能方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景go库下载初始化数据【1】建表【2】插入数据【3】查看数据4、代码示例【1】gorm结构体定义【2】分页结构体

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到