js實(shí)現(xiàn)櫥窗展示效果
本文實(shí)例為大家分享了js實(shí)現(xiàn)櫥窗展示的具體代碼,供大家參考,具體內(nèi)容如下
思路
1、獲取需要的標(biāo)簽
2、求出滾動(dòng)條的長度(公式:滾動(dòng)條長度 = ( 盒子的寬度 / 內(nèi)容的寬度) * 盒子的寬度)
3、監(jiān)聽鼠標(biāo)按下事件:3 設(shè)置起始位置
4、監(jiān)聽鼠標(biāo)的移動(dòng):
4.1求出移動(dòng)的位置
4.2判斷滾動(dòng)條的位置(防超出)
4.3 移動(dòng)滾動(dòng)條、商品滾動(dòng)(公式:內(nèi)容走的距離 = (內(nèi)容的長度 - 盒子的長度) / (盒子長度 - 滾動(dòng)條的長度) * 滾動(dòng)條走的距離);
5、監(jiān)聽鼠標(biāo)的離開事件:把鼠標(biāo)的移動(dòng)事件設(shè)置為無即可。
<script> window.onload = function (){ //1.獲取需要的標(biāo)簽 var box = document.getElementById("box"); var box_top = box.children[0]; var box_bottom = box.children[1]; var mask = box_bottom.children[0]; //2.獲取滾動(dòng)條長度 // 滾動(dòng)條長度 = ( 盒子的寬度 / 內(nèi)容的寬度) * 盒子的寬度 var mask_length = (box.offsetWidth /box_top.offsetWidth) * box.offsetWidth; mask.style.width = mask_length + "px"; //3.監(jiān)聽鼠標(biāo)按下的事件 mask.onmousedown = function (event){ var event = event || window.event; //3.1設(shè)置起始位置 var beginX = event.clientX - mask.offsetLeft; //3.2 監(jiān)聽鼠標(biāo)的移動(dòng) document.onmousemove =function (event){ var event = event || window.event; //3.2.1求移動(dòng)的位置 var endX = event.clientX - beginX; //3.2.2處理邊界值 if(endX < 0){ endX = 0 }else if(endX >= box.offsetWidth - mask.offsetWidth){ endX = box.offsetWidth - mask.offsetWidth; } //3.2.3讓滾動(dòng)條滾動(dòng) mask.style.left = endX + "px"; //3.2.4 讓商品隨著滾動(dòng) //公式:內(nèi)容走的距離 = (內(nèi)容的長度 - 盒子的長度) / (盒子長度 - 滾動(dòng)條的長度) * 滾動(dòng)條走的距離 var content_len = (box_top.offsetWidth - box.offsetWidth) / (box.offsetWidth - mask.offsetWidth) * endX; box_top.style.left = -content_len + "px"; return false; }; document.onmouseup = function (){ document.onmousemove = null; } } } </script>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
比較不錯(cuò)的函數(shù)式JavaScript編程指南教程
你是否知道JavaScript其實(shí)也是一個(gè)函數(shù)式編程語言呢?本指南將教你如何利用JavaScript的函數(shù)式特性。2008-05-05js關(guān)閉瀏覽器窗口及檢查瀏覽器關(guān)閉事件
js關(guān)閉瀏覽器窗口,不彈出提示框。支持ie6+,火狐,谷歌等瀏覽器,下面以一個(gè)示例為大家詳細(xì)介紹下具體的實(shí)現(xiàn)方法,感興趣的朋友可以參考下2013-09-09深入JavaScript高級(jí)程序設(shè)計(jì)之對象、數(shù)組(棧方法,隊(duì)列方法,重排序方法,迭代方法)
這篇文章主要介紹了深入JavaScript高級(jí)程序設(shè)計(jì)之對象、數(shù)組(棧方法,隊(duì)列方法,重排序方法,迭代方法)的相關(guān)資料,需要的朋友可以參考下2015-12-12頁面調(diào)用單個(gè)swf文件,嵌套出多個(gè)方法。
頁面調(diào)用單個(gè)swf 文件,嵌套出多個(gè)方法,需要的朋友可以參考下。2011-11-11How to Auto Include a Javascript File
How to Auto Include a Javascript File...2007-02-02js實(shí)現(xiàn)從右往左勻速顯示圖片(無縫輪播)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)從右往左勻速顯示圖片,無縫輪播,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-06-06淺談js函數(shù)中的實(shí)例對象、類對象、局部變量(局部函數(shù))
下面小編就為大家?guī)硪黄獪\談js函數(shù)中的實(shí)例對象、類對象、局部變量(局部函數(shù))。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11js實(shí)現(xiàn)非常簡單的焦點(diǎn)圖切換特效實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)非常簡單的焦點(diǎn)圖切換特效,是一個(gè)非常簡單的js焦點(diǎn)圖切換效果,涉及javascript操作鼠標(biāo)事件與圖片的相關(guān)技巧,需要的朋友可以參考下2015-05-05