用JS怎样实现一个可拖动的展示框效果,方法是什么
Admin 2022-06-21 群英技术资讯 758 次浏览
在实际应用中,我们有时候会遇到“用JS怎样实现一个可拖动的展示框效果,方法是什么”这样的问题,我们该怎样来处理呢?下文给大家介绍了解决方法,希望这篇“用JS怎样实现一个可拖动的展示框效果,方法是什么”文章能帮助大家解决问题。本文实例为大家分享了JavaScript实现橱窗展示效果的具体代码,供大家参考,具体内容如下
1.先搭架子
* {
margin: 0;
padding: 0;
}
.box {
width: 800px;
height: 190px;
border: 1px solid #000;
margin: 100px auto;
}
ul {
list-style: none;
display: flex;
}
ul img {
vertical-align: top;
}
.progress {
width: 100%;
height: 30px;
background: #ccc;
}
.progress>.line {
width: 100px;
height: 100%;
background: orange;
border-radius: 15px;
}
<div class="box">
<ul>
<li>
<img src="images/img1.jpg" alt="">
</li>
<li>
<img src="images/img2.jpg" alt="">
</li>
<li>
<img src="images/img3.jpg" alt="">
</li>
<li>
<img src="images/img4.jpg" alt="">
</li>
<li>
<img src="images/img5.jpg" alt="">
</li>
<li>
<img src="images/img6.jpg" alt="">
</li>
<li>
<img src="images/img7.jpg" alt="">
</li>
<li>
<img src="images/img8.jpg" alt="">
</li>
<li>
<img src="images/img9.jpg" alt="">
</li>
<li>
<img src="images/img10.jpg" alt="">
</li>
</ul>
<div class="progress">
<div class="line"></div>
</div>
</div>
2.逻辑部分
拿到需要操作的元素
计算ul的宽度
设置ul的宽度
计算滚动条的宽度
设置滚动条的宽度
监听鼠标按下的事件
监听鼠标移动事件
.box {
overflow: hidden;
}
ul {
position: relative;
}
.progress {
position: relative;
}
.progress>.line {
position: absolute;
left: 0;
top: 0;
}
//1.拿到需要操作的元素
const oUl = document.querySelector("ul");
const oItems = oUl.querySelectorAll("li");
const oProgress = document.querySelector(".progress");
const oLine = document.querySelector(".line");
const oBox = document.querySelector(".box");
//2.计算ul的宽度
const ulWidth = oItems[0].offsetWidth * oItems.length;
//3.设置ul的宽度
oUl.style.width = ulWidth + 'px';
//4.计算滚动条的宽度
// 滚动条的宽度/滚动条滚动范围 = 容器的宽度/内容的范围
const progressWidth = oProgress.offsetWidth;
const boxWidth = oBox.offsetWidth;
const lineWidth = boxWidth / ulWidth * progressWidth;
//5.设置滚动条的宽度
oLine.style.width = lineWidth + 'px';
// 计算滚动条最大能够滚动的范围
const maxLineX = progressWidth - lineWidth;
// 计算图片最大能够滚动的范围
const maxImgX = boxWidth - ulWidth;
//6.监听鼠标按下的事件
oLine.onmousedown = function(e) {
e = e || window.e;
//a.拿到滚动条当前的位置
let begin = parseFloat(oLine.style.left) || 0;
//b.拿到鼠标在滚动条中按下的位置
let mouseX = e.pageX - oBox.offsetLeft;
//7.监听鼠标移动事件
oLine.onmousemove = function(e) {
e = e || window.e;
//c.拿到鼠标在滚动条中移动之后的位置
let moveMouseX = e.pageX - oBox.offsetLeft;
//d.计算偏移位
let offsetX = moveMouseX - mouseX + begin;
//e.安全校验
offsetX = offsetX < 0 ? 0 : offsetX;
offsetX = offsetX > maxLineX ? maxLineX : offsetX;
//f.重新设置滚动条的位置
oLine.style.left = offsetX + 'px';
//g.计算图片的滚动距离
// 滚动条滚动的距离 / 滚动条最大能够滚动的范围 = 图片滚动的距离 / 图片最大能够滚动的范围
// 滚动条滚动的距离 / 滚动条最大能够滚动的范围 * 图片最大能够滚动的范围 = 图片滚动的距离
const imgOffsetX = offsetX / maxLineX * maxImgX;
// h.重新设置图片的位置
oUl.style.left = imgOffsetX + "px";
};
};
document.onmouseup = function() {
oLine.onmousemove = null;
}

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
如何为 Node.js 的 require 函数添加钩子?下面本篇文章就来带大家了解一下require函数中添加钩子的方法,希望对大家有所帮助!
这篇文章主要和大家分享用vue实现切换图片效果的小案例,点击按钮可以实现向前切换,向后切换和顺序切换的效果。下面我们就来看看具体的实现代码。
怎样用JavaScript写一个简单的图片切换效果?图片切换效果的应用场景有很多,我们在很多网站上都能看到,图片切换效果也是比较实用的功能,很多朋友比较好奇是怎么实现的,下面我们就来看看怎样用JavaScript实现图片切换。
这篇文章给大家分享的是隐藏域的作用和获取隐藏域中的值的方法,文中的获取隐藏域中的值的示例是使用jQuery实现的,下文有详细的介绍,有需要的朋友可以参考,接下来就跟随小编来一起学习一下吧!
我们商品分类的信息太多,如果每一行都显示同一个颜色的话会让人看的眼花,为了提高用户体验,减少用户看错的情况,需要对表格进行隔行
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008