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

相关文章

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。