用JS怎样实现一个可拖动的展示框效果,方法是什么
Admin 2022-06-21 群英技术资讯 520 次浏览
本文实例为大家分享了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进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要给大家分享的是Vue 组件化基本使用,所谓组件化,就是把页面拆分成多个组件,每个组件依赖的 CSS、JS、模板、图片等资源放在一起开发和维护。 因为组件是资源独立的,所以组件在系统内部可复用,组件和组件之间可以嵌套,下面来看文章学习内容吧
JS学习有哪些基本语法规则要了解,一些朋友可能会遇到这方面的问题,对此在下文小编向大家来讲解一下,内容详细,易于理解,希望大家阅读完这篇能有收获哦,有需要的朋友就往下看吧!
vue怎样做点击展开收起的功能?在很多网站上都能看到点击展开收起的功能,点击展开收起的效果能让网页设计更简洁好看,也是比较使用的,因此这篇文章就给大家分享一下vue实现点击展开收起效果的方法。
vue刷新数据丢失的情况怎样解决?对于这个问题,相信不少朋友都又遇到,也就是进行F5页面刷新的时候,页面的数据会丢失的情况,那么我们有什么解决方法呢?下面我们了解看看。
生成函数调用,没有执行函数体中的函数体,而是返回一个生成器。生成器函数会从上次yield语句的位置运行到下一个yield语句的位置。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008