news 2026/2/26 17:13:45

动态类名在 <swiper-slide 的复制项中没有起作用的解决方法

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
动态类名在 <swiper-slide 的复制项中没有起作用的解决方法

动态类名在 <swiper-slide 的复制项中没有起作用的解决方法

错误代码

<swiper:options="swiperOption"ref="mySwiper"class="bottom-ul"><swiper-slide v-for="(d, i) in bottomData":key="i"class="menu-item"><!--@click="btnClick(d.groupName)"--><liclass="menu-li":class="{ active: activeGroup === d.groupName }"><!--<i style=""><img:src="d.src"></i>--><span>{{d.groupName}}</span></li></swiper-slide>

核心原因是复制的 slide 是 Swiper 纯 DOM 层面的复制,不会触发 Vue 的响应式渲染,所以复制项里的 Vue 指令(如 :class)完全失效。

问题本质拆解

v-for 只渲染了真实的 slide,这些 slide 内的<li>受 Vue 响应式控制,active 类名正常;
Swiper 开启 loop 后,会在 DOM 层面复制真实 slide 生成 duplicate 项,但复制的只是静态 DOM 结构,没有 Vue 的响应式绑定,所以 :class 指令不会执行,active 类名自然不会出现在复制项的<li>上;
当切换到复制 slide 时,视觉上看到的是复制项的<li>,但它没有 active 类,导致选中样式丢失。
解决方案:手动同步复制项的 active 类
核心思路是:监听 Swiper 的切换事件和 Vue 的 activeGroup 变化,手动给真实 slide + 复制 slide 中匹配的<li>添 / 删 active 类,绕过 Vue 响应式的限制。

<template><div><swiper:options="swiperOption"ref="mySwiper"class="bottom-ul"@slideChange="handleSlideChange"><swiper-slide v-for="(d, i) in bottomData":key="i"class="menu-item":data-group-name="d.groupName"<!--给真实slide标记分组名,方便DOM查找-->><liclass="menu-li":class="{ active: activeGroup === d.groupName }"><span>{{d.groupName}}</span></li></swiper-slide></swiper></div></template><script>import{Swiper,SwiperSlide}from'swiper/vue';import'swiper/css';import'swiper/css/navigation';import'swiper/css/pagination';importSwiperCorefrom'swiper';exportdefault{components:{Swiper,SwiperSlide},data(){return{bottomData:[// 示例数据{groupName:'分组1'},{groupName:'分组2'},{groupName:'分组3'},{groupName:'分组4'}],activeGroup:'分组2',// 默认选中的分组swiperOption:{centeredSlides:true,// 居中展示loop:true,// 循环(导致复制slide)slidesPerView:'auto',// 自适应宽度loopAdditionalSlides:5,// 增加复制slide数量initialSlide:1,// 初始从真实slide开始centeredSlidesBounds:false}};},watch:{// 监听activeGroup变化,同步更新所有slide(真实+复制)的active类activeGroup(newVal){this.syncActiveClass(newVal);}},mounted(){// 初始化时同步一次active类(确保复制项也有初始选中样式)this.$nextTick(()=>{this.syncActiveClass(this.activeGroup);});},methods:{// 核心方法:同步真实slide和复制slide的active类syncActiveClass(activeName){if(!this.$refs.mySwiper)return;// 1. 先移除所有slide内li的active类(避免多个active)document.querySelectorAll('.bottom-ul .menu-li').forEach(li=>{li.classList.remove('active');});// 2. 找到所有包含目标groupName的slide(真实+复制),给其li加active类consttargetSlides=document.querySelectorAll(`.bottom-ul .menu-item[data-group-name="${activeName}"]`);targetSlides.forEach(slide=>{constli=slide.querySelector('.menu-li');if(li)li.classList.add('active');});},// Swiper切换事件:同步activeGroup和active类handleSlideChange(){constswiperInstance=this.$refs.mySwiper.swiper;// 获取当前激活slide的真实索引constrealIndex=swiperInstance.realIndex;// 更新activeGroup为当前真实slide对应的分组名this.activeGroup=this.bottomData[realIndex].groupName;// 同步复制slide的active类this.syncActiveClass(this.activeGroup);},// 如果你有手动点击li的方法,也要同步调用syncActiveClassbtnClick(groupName){this.activeGroup=groupName;this.syncActiveClass(groupName);// 可选:点击后让对应的slide居中constswiperInstance=this.$refs.mySwiper.swiper;consttargetIndex=this.bottomData.findIndex(d=>d.groupName===groupName);swiperInstance.slideTo(targetIndex+1,300,true);// +1 适配loop的索引偏移}}};</script><style scoped>/* 示例样式:方便看选中效果 */.menu-li{list-style:none;padding:8px 16px;cursor:pointer;}.menu-li.active{background-color:#409eff;color:white;border-radius:4px;}.bottom-ul{width:100%;overflow:hidden;}.menu-item{display:inline-block;margin:08px;}</style>
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/26 12:48:03

Linux网络设备驱动框架深度解析:枚举、注册、挂载全流程

在Linux内核网络子系统中,网络设备驱动是连接硬件与协议栈的核心桥梁。与字符设备、块设备驱动不同,网络设备驱动有其独特的抽象模型和实现逻辑。本文将从核心原理出发,逐步拆解网络设备驱动的枚举、注册、挂载全流程,结合代码示例帮你吃透这一核心技术。 一、核心原理:L…

作者头像 李华
网站建设 2026/2/19 16:01:40

余行补位方法论:构建专精特新企业产业生态领导力的实践体系

余行补位方法论&#xff1a;构建专精特新企业产业生态领导力的实践体系 一、生态领导力的价值重估&#xff1a;从供应商到标准制定者的跃迁 1.1 传统企业价值的四个边界 技术边界&#xff1a;核心技术保护范围决定竞争壁垒 市场边界&#xff1a;目标客户群体限定增长空间 组…

作者头像 李华
网站建设 2026/2/18 8:56:51

基于ESP32的仓库智能防火监测系统

阅读提示 博主是一位拥有多年毕设经验的技术人员&#xff0c;如果本选题不适用于您的专业或者已选题目&#xff0c;我们同样支持按需求定做项目&#xff0c;论文全套&#xff01;&#xff01;&#xff01; 博主介绍 CSDN毕设辅导第一人、靠谱第一人、全网粉丝50W,csdn特邀作者…

作者头像 李华
网站建设 2026/2/3 15:12:42

conda下安装cuda11.8和cudnn

当需要多个cuda版本的时候我们可以将cuda安装到虚拟机里。 conda install -c nvidia cuda-runtime11.8conda install -c nvidia cudnn

作者头像 李华
网站建设 2026/2/22 4:38:29

Halcon图像滤波:均值滤波、中值滤波、高斯滤波、高通滤波、标准差滤波

*图像滤波:•滤波原理&#xff1a;图像滤波&#xff0c;即在尽量保留图像细节特征的条件下对目标图像的噪声进行抑制&#xff0c;是图像预处理中不可缺少的操作&#xff0c;其处理效果的好坏将直接影响到后续图像处理和分析的有效性和可靠性。图像滤波的主要目的&#xff1a;为…

作者头像 李华
网站建设 2026/2/23 11:31:48

国产Jira方案哪家强?2026年Jira替代工具测评指南

如果你正在做国产 Jira 方案与 Jira 替代工具选型&#xff0c;真正的难点从来不是有没有看板&#xff0c;而是能否承接你组织的流程、权限、数据与知识沉淀。本文测评 8 款工具&#xff1a;ONES、云效、华为云 CodeArts、CODING DevOps、TAPD、极狐GitLab、Gitee Issue、GitCod…

作者头像 李华