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

相关文章

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

Debian 13升级后网络转发等功能异常怎么办? 并非错误而是管理机制变更

《Debian13升级后网络转发等功能异常怎么办?并非错误而是管理机制变更》很多朋友反馈,更新到Debian13后网络转发等功能异常,这并非BUG而是Debian13Trixie调整... 日前 Debian 13 Trixie 发布后已经有众多网友升级到新版本,只不过升级后发现某些功能存在异常,例如网络转

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2