Swiper插件 loop:true时引发绑定dom的click事件无效及解决方案

现象

在使用 swiper 这个库的时候,一旦设置 loop:true 的时候,有时会遇到 dom 绑定事件无法触发的问题。

原因

当loop模式下slides前后会clone若干个slide,从而形成一个环路,但是却不会复制绑定在dom上的click事件。

解决

不要将click事件绑定在dom上,而是在new Swiper()中的on回调函数中统一调用。

 

梨子

 let _this = this;    // 注意 new Swiper中的this指向的是swiper对象,因此要现在外面声明当前组件的this

 new Swiper('.gameList-swiper-container', {

            loop: true,   // 引发问题的根源

            autoplay:{   disableOnInteraction: false  },

            on:{

                click(e){

                     if(!e.target.id) return;   // e.target.id 主要起传参的作用

                     // console.log(e.target.id)

                     _this.props.changeGameData(e.target.id);

                }

            },

            slidesPerView: 4,

            spaceBetween: 20,

 });

 

<div className="swiper-container gameList-swiper-container">

              <div className="swiper-wrapper">

                            {gameList.map((item,index)=>(

                                <div key={index} className="swiper-slide clearfix">

                                        <h2>{item.gameTitle}</h2>

                                        <div className='slideItemBtn' id={[item.gameClass,item.type,item.gameId]}>进入游戏</div>

                                </div>

                            ))}

                </div>

  </div>

 

 

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值