您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關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" > </li> <li> <img src="images/img2.jpg" > </li> <li> <img src="images/img3.jpg" > </li> <li> <img src="images/img4.jpg" > </li> <li> <img src="images/img5.jpg" > </li> <li> <img src="images/img6.jpg" > </li> <li> <img src="images/img7.jpg" > </li> <li> <img src="images/img8.jpg" > </li> <li> <img src="images/img9.jpg" > </li> <li> <img src="images/img10.jpg" > </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; }
關于“JavaScript如何實現櫥窗展示效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。