老师帮看一下代码,为什么左按钮没有实现瞬间移动
相关代码:
<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';
10
收起
正在回答
2回答
同学你好,应该是火狐浏览器自身解析的问题,左侧按钮点击事件中定时器间隔时间调整为500,再测试下,如下图所示:
祝学习愉快~
好帮手慕慕子
2021-04-28 17:06:21
同学你好,对于你的问题解答如下:
1、老师使用最新版的Chrome浏览器测试同学的代码,点击左右按钮效果实现是正确的。建议同学再测试下。
2、节流锁的实现思想都是一样的,但是因为需要实现的效果不同,具体情况具体分析,所以代码书写会有些不一样。
这里添加节流锁的作用是:因为在短时间内多次点击按钮,上一张动画还未执行完就显示下一张,会导致效果不对,所以添加节流锁,在点击按钮后,将lock设置为false,结合定时器在500ms(动画完成)后才将lock值改为true,由于在这500ms内再次点击按钮,不允许再次移动图片,所以直接return不执行后面的代码就可以了。
3、可以这么理解。
祝学习愉快~
相似问题
登录后可查看更多问答,登录/注册
恭喜解决一个难题,获得1积分~
来为老师/同学的回答评分吧
0 星