0

0

如何在 Swiper.js 中正确启用 Fade 淡入淡出切换效果

花韻仙語

花韻仙語

发布时间:2026-01-09 10:54:19

|

212人浏览过

|

来源于php中文网

原创

如何在 Swiper.js 中正确启用 Fade 淡入淡出切换效果

swiper 9+ 版本采用模块化架构,启用 fade 效果必须显式导入并注册 `effectfade` 模块,否则即使设置了 `effect: "fade"` 仍会回退为默认的 slide 滚动效果。

在 Swiper 9.x 及更高版本(包括你使用的 9.4.1 和 10.0.4)中,所有高级功能(如 fade、cube、flip 等切换效果)均已从核心包中剥离,改为按需导入的独立模块。这意味着仅配置 effect: "fade" 是无效的——Swiper 核心并不内置该逻辑,若未注册对应模块,它将自动忽略 effect 配置,降级使用默认的 slide 效果。

✅ 正确做法是:

  1. 显式导入 EffectFade 模块;
  2. 将其传入 modules 数组选项中;
  3. 保持 effect: "fade" 配置不变。

以下是修正后的完整初始化代码(适配 Laravel Blade + Vite 环境):

Mapify
Mapify

Mapify是由Xmind推出的AI思维导图生成工具,原名ChatMind

下载
import Swiper from 'swiper';
import { EffectFade } from 'swiper/modules';

const options = {
  modules: [EffectFade], // ✅ 必须包含此项
  slidesPerView: 1,
  effect: 'fade',        // ✅ 保留 fade 配置
  spaceBetween: 16,
  speed: 300,
  loop: true,
  allowTouchMove: false, // 可选:禁用触控滑动(适用于纯按钮控制场景)
  // ? 建议添加:避免 fade 时出现闪烁或布局抖动
  fadeEffect: {
    crossFade: true // 启用交叉淡入淡出,视觉更平滑(Swiper 10+ 默认启用,9.x 需显式设置)
  }
};

// 初始化多个同步滑块
const slider_1 = new Swiper('#best-sellers-slider-1', options);
const slider_2 = new Swiper('#best-sellers-slider-2', options);
const slider_3 = new Swiper('#best-sellers-slider-3', options);

// 统一控制按钮
const nextButton = document.querySelector('#best-seller-next');
const prevButton = document.querySelector('#best-seller-prev');

nextButton?.addEventListener('click', () => {
  slider_1.slideNext();
  slider_2.slideNext();
  slider_3.slideNext();
});

prevButton?.addEventListener('click', () => {
  slider_1.slidePrev();
  slider_2.slidePrev();
  slider_3.slidePrev();
});

⚠️ 注意事项:

  • 模块导入路径需准确:Swiper 9+ 使用 swiper/modules 路径,而非旧版的 swiper/dist/css/swiper.css 或全局插件式引入;
  • CSS 不可省略:确保已在项目中引入 Swiper 样式(例如在 resources/css/app.css 中添加 @import 'swiper/css';),否则 fade 动画可能因缺少 .swiper-fade 类样式而失效;
  • 多滑块同步建议加防抖/锁机制:若滑块数量较多或网络较慢,可考虑在按钮点击时添加 slider.isTransitioning 判断,避免重复触发;
  • Laravel Vite 环境下:确认 vite.config.js 中已正确解析 .css 和 node_modules,且 @vite('resources/js/app.js') 已注入 Blade 模板。

总结:Swiper 的模块化设计提升了打包体积可控性,但也要求开发者明确声明所需功能。只要补全 modules: [EffectFade],fade 效果即可立即生效,无需降级版本或修改 HTML 结构。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

316

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

270

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

367

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

366

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

81

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

64

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

66

2025.08.05

css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

509

2023.06.15

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.7万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.8万人学习

CSS教程
CSS教程

共754课时 | 18.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号