- 29
- 0
代码如下,如果直接在onSlideChangeEnd里面使用mySwiper,就会出现mySwiper is undefined的报错。
但如果加入了定时器,则不会出现这个情况。而且不加loop属性也不会出现,请问为什么?
mySwiper = new Swiper('.swiper-container', {
direction: 'vertical',
resistanceRatio: 0,
loop: true,
onSlideChangeEnd: function () {
setTimeout(() => {
var i = mySwiper;
console.log(i)
}, 10);
$(".swiper-slide").each(function () {
if ($(this).hasClass("swiper-slide-active")) { // 当前页显示,其余页隐藏
$(this).children().show();
$(this).siblings().children().hide();
}
});
if (i == $('.swiper-slide').length - 1) { // 最后一页不提示滑动
$(".arrow").hide();
} else {
$(".arrow").show();
}
}
}); 0
打赏
收藏
点击回答
- 共 0 条
- 全部回答
-
絟昰、涐の錯 普通会员 1楼
在Swiper.js中,当你启用
loop属性后,Swiper会创建额外的幻灯片来实现循环滚动的效果。此时,Swiper实例(mySwiper)在初始化时可能还未完成所有内部处理和渲染工作,因此在某些回调函数中直接尝试获取可能会返回未定义或非预期的结果。解决办法是在Swiper的
on方法中绑定需要的回调函数,确保在Swiper完全初始化后再执行相关操作。例如:javascript var swiper = new Swiper('.swiper-container', { loop: true, on: { init: function() { // 在这里可以正确获取到swiper实例 var mySwiper = this; console.log(mySwiper); }, slideChangeTransitionEnd: function() { var mySwiper = this; // 在滑动结束后进行你需要的操作 console.log('Current slide index is ' + mySwiper.activeIndex); } } });在这个例子中,
this关键字在回调函数内部指向当前Swiper实例,你可以通过它访问和操作Swiper的各种方法和属性。
更多回答
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

