2022-02-16 工作记录--Swiper-实现跑马灯效果:鼠标经过时停止滑动,鼠标离开后继续滑动

Swiper-实现跑马灯效果:鼠标经过时停止滑动,鼠标离开后继续滑动

一、效果图

在这里插入图片描述

二、对应代码

swiper详情可见swiper官网,下面给出实现跑马灯效果的代码】

【注意】 下面CSSJS代码里的swiper-container1就是swiper-container的新增类名。

  • 这样处理的原因: 防止代码里有多个swiper时,有些swiper想实现跑马灯效果,但有些swiper不想实现跑马灯效果,就可以单独取个类名对这些swiper进行区分喔~
  • 小萝卜儿们🥕一定要注意哟,不然试了没效果,找大半天原因哈~⚠️

CSS

.swiper-wrapper增加样式transition-timing-function: linear;实现swiper匀速轮播~

/**【关键】注意:下面👇🏻的swiper-container1是我给swiper-container新增的类名,其与swiper-container并列 */
.swiper-container1>.swiper-wrapper {
	-webkit-transition-timing-function: linear;    /*之前是ease-out*/
  	-moz-transition-timing-function: linear;
  	-ms-transition-timing-function: linear;
  	-o-transition-timing-function: linear;
  	transition-timing-function: linear;
}

JS

// 实例化swiper
var swiper1 = new Swiper('.swiper-container1', {              
       slidesPerView: 4, // 设置slider容器能够同时显示的slides数量(carousel模式)
       slidesPerGroup: 1, // 在carousel mode下定义slides的数量多少为一组
       loop: true, // 设置为true 则开启loop(无限循环)模式
       freeMode: true, //【关键】设置为true则变为free模式
       speed:6000, //【关键】匀速时间
       autoplay: { // 自动播放
            delay: 0, //【关键】自动切换的时间间隔,单位ms
      },
 })
        
// 实现 鼠标移入swiper-container时,轮播图停止;鼠标移出时,轮播图继续
var lastNeedSwiperSpeed; // 平滑移动到swiper1.translate需要的速度
//鼠标移入悬停
$('.swiper-container1').on('mouseenter', function(){
    // swiper1.getTranslate()为当前实时的位移,swiper1.translate为过度结束的位移,swiper1.slideWidth为slide的宽度px
    // 计算之后平滑移动到swiper1.translate需要的速度,并储存下来
    lastNeedSwiperSpeed = Math.abs(Math.abs(swiper1.getTranslate()) - Math.abs(swiper1.translate)) / (swiper1.slideWidth + swiper1.params.spaceBetween) * swiper1.params.speed;
    // setTranslate到当前位置,并停止autoplay
    swiper1.setTranslate(swiper1.getTranslate());
    swiper1.autoplay.stop(); // 参考文档:https://www.swiper.com.cn/api/autoplay/112.html
})
 //鼠标移出滚动
$('.swiper-container1').on('mouseleave', function(){
    // 使用刚才计算出的速度,移动到当前slide,即将当前slide的移动到头部的动画完成,开启autoplay
   swiper1.slideTo(swiper1.activeIndex, lastNeedSwiperSpeed);
   swiper1.autoplay.start(); // 参考文档:https://www.swiper.com.cn/api/autoplay/111.html
 })
  • 10
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 12
    评论
实现跑马灯效果,你可以使用Swiper Web组件的swiper-container标签结合一些配置选项。下面是一个示例代码: ```html <!DOCTYPE html> <html> <head> <!-- 引入SwiperCSS文件 --> <link rel="stylesheet" href="https://unpkg.com/swiper/swiper-bundle.min.css"> </head> <body> <!-- 创建一个swiper容器 --> <div class="swiper-container"> <!-- 创建一个swiper-wrapper容器,用于包裹轮播项 --> <div class="swiper-wrapper"> <!-- 创建多个swiper-slide,每个slide代表一个轮播项 --> <div class="swiper-slide">Slide 1</div> <div class="swiper-slide">Slide 2</div> <div class="swiper-slide">Slide 3</div> <!-- 可以根据需求添加更多的轮播项 --> </div> </div> <!-- 引入Swiper的JS文件 --> <script src="https://unpkg.com/swiper/swiper-bundle.min.js"></script> <script> // 初始化Swiper实例 var swiper = new Swiper('.swiper-container', { // 设置轮播方向为水平 direction: 'horizontal', // 设置循环轮播 loop: true, // 设置自动播放 autoplay: { delay: 2000, // 延迟间,单位为毫秒 disableOnInteraction: false, // 用户操作后是否禁止自动播放 }, }); </script> </body> </html> ``` 上述代码中,我们使用了Swiper Web组件的swiper-container标签作为轮播容器,swiper-wrapper标签包裹轮播项,每个轮播项使用swiper-slide标签表示。通过配置选项,我们设置了水平方向的循环轮播,并启用了自动播放功能。 你可以根据自己的需求修改轮播项的内容和样式,以及调整配置选项来实现所需的跑马灯效果

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 12
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小呀小萝卜儿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值