老师帮看一下代码,为什么左按钮没有实现瞬间移动

老师帮看一下代码,为什么左按钮没有实现瞬间移动

相关代码:

<style>
* {
margin: 0;
padding: 0;
}

.carousel {
width: 650px;
height: 360px;
border: 1px solid #000;
margin: 50px auto;
position: relative;
overflow: hidden;
}

.carousel ul {
list-style: none;
width: 6000px;
position: relative;
left: 0;
transition: left 0.5s linear 0s;
}

.carousel ul li {
float: left;
}

.carousel .leftbtn {
width: 50px;
height: 50px;
background-color: rgb(75, 188, 223);
border-radius: 50%;
position: absolute;
left: 20px;
top: 50%;
margin-top: -25px;
}

.carousel .rightbtn {
width: 50px;
height: 50px;
background-color: rgb(75, 188, 223);
border-radius: 50%;
position: absolute;
right: 20px;
top: 50%;
margin-top: -25px;
}
</style>
</head>

<body>
<div class="carousel" id="carousel">
<ul id="list">
<li><img src="images/beijing/0.jpg" alt=""></li>
<li><img src="images/beijing/1.jpg" alt=""></li>
<li><img src="images/beijing/2.jpg" alt=""></li>
<li><img src="images/beijing/3.jpg" alt=""></li>
<li><img src="images/beijing/4.jpg" alt=""></li>
</ul>
<!-- 执行一段空的javascript代码,防止刷新页面-->
<a href="JavaScript:;" class='leftbtn' id='leftbtn'></a>
<a href="JavaScript:;" class='rightbtn' id='rightbtn'></a>
</div>

<script>
// 得到按钮和ul,ul整体进行运动
var leftbtn = document.getElementById('leftbtn');
var rightbtn = document.getElementById('rightbtn');
var list = document.getElementById('list');

// 克隆第一张图片
var cloneli = list.firstElementChild.cloneNode(true);
list.appendChild(cloneli);

// 当前ul显示到第几张了,从0开始数
var idx = 0;

// 节流锁
var lock = true;

// 右边按钮监听
rightbtn.onclick = function () {
// 判断锁的状态
if (!lock) return;

// 给list加过渡,为什么要加?css中不是已经加了么?这是因为最后一张图片会把过渡去掉
list.style.transition = 'left .5s linear 0s';
idx++;
if (idx > 4) {
// 设置一个延迟器,延迟器的功能就是将ul瞬间拉回0的位置,延迟器的目的就是让过渡动画结束之后
setTimeout(function () {
// 取消掉过渡,因为要的是瞬间移动,不是“咕噜”回去
list.style.transition = 'none';
list.style.left = 0;
idx = 0;
}, 500);
}
list.style.left = -idx * 650 + 'px';

lock=false;

// 函数节流
setTimeout(function () {
lock = true;
}, 500);
}

// 左边按钮监听
leftbtn.onclick = function () {
if (!lock) return;

// 判断是不是第0张,如果是,就要瞬间用假的替换真的
if (idx == 0) {
// 取消掉过渡,因为要的是瞬间移动,不是“咕噜”过去
list.style.transition = 'none';
// 直接瞬间移动到最后的假图片上
list.style.left = -5 * 650 + 'px';
// 设置一个延时器,这个延迟器的延时时间可以是0毫秒,虽然是0毫秒,但是可以让我们过渡先是瞬间取消,然后加上
setTimeout(function () {
// 加过渡
list.style.transition = 'left .5s ease 0s';
// idx改为真正的最后一张图片的编号
idx = 4;
list.style.left = -idx * 650 + 'px';
}, 0);
} else {
idx--;
list.style.left = -idx * 650 + 'px';
}
lock=false;

// 函数节流
setTimeout(function () {
lock = true;
}, 500);
}
</script>
</body>

为什么视频中老师的关锁动作是在if (!lock) return之后?(效果也能实现);之前学节流锁是判断关闭就不执行,判断开启就往下执行代码,执行代码完毕后关锁。然后再用延迟器开锁。

             lock=false;

// 函数节流
setTimeout(function () {
lock = true;
}, 500);

这个代码中的5怎么得到?是处于第0张时候点击左边,往左就是空的了,然后需要经过第0张直到第4张(就是把第4张显示出来),也就是经过5张图片的距离,这么理解对吧?

// 直接瞬间移动到最后的假图片上
list.style.left = -5 * 650 + 'px';


正在回答

登陆购买课程后可参与讨论,去登陆

2回答

同学你好,应该是火狐浏览器自身解析的问题,左侧按钮点击事件中定时器间隔时间调整为500,再测试下,如下图所示:

http://img1.sycdn.imooc.com//climg/608931df0976c8ce11470449.jpg

祝学习愉快~

好帮手慕慕子 2021-04-28 17:06:21

同学你好,对于你的问题解答如下:

1、老师使用最新版的Chrome浏览器测试同学的代码,点击左右按钮效果实现是正确的。建议同学再测试下。

2、节流锁的实现思想都是一样的,但是因为需要实现的效果不同,具体情况具体分析,所以代码书写会有些不一样。

这里添加节流锁的作用是:因为在短时间内多次点击按钮,上一张动画还未执行完就显示下一张,会导致效果不对,所以添加节流锁,在点击按钮后,将lock设置为false,结合定时器在500ms(动画完成)后才将lock值改为true,由于在这500ms内再次点击按钮,不允许再次移动图片,所以直接return不执行后面的代码就可以了。

3、可以这么理解。

祝学习愉快~

  • 上次有个代码也是我测试不太对,老师也是帮测试是正确的。我用的是火狐浏览器。

    我刚才有一下点击左边是效果实现了的,但是再次点击就又不得了。另外就是节流锁我是理解的,可能我是比较习惯顺下来理解真个代码‘先到这,再到这’这样的思路比较多。所以一开始是判断关闭就return。否则执行以下代码,(完毕后)lock=false关锁,再写延时器开锁。

    2021-04-28 17:10:24
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
意见反馈 帮助中心 APP下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师