javascript實現(xiàn)平滑無縫滾動
本文我們實現(xiàn)純JS方式的滾動廣告效果,供大家參考,具體內容如下
先show一下成品:
首先是網(wǎng)頁樣式:
#demo { background: #FFF; overflow:hidden; border: 1px dashed #CCC; width: 1280px; height:200px; } #demo img { border: 3px solid #F2F2F2; } #indemo { float: left; width: 800%; } #demo1 { float: left; } #demo2 { float: left; }
布局如下:
<div id="demo"> <div id="indemo"> <div id="demo1"> <a href="#"><img src="banner.jpg" border="0" /></a> <a href="#"><img src="banner2.jpg" border="0" /></a> </div> <div id="demo2"></div> </div> </div>
具體的JS實現(xiàn):
<script> var speed=10; var tab=document.getElementById("demo"); var tab1=document.getElementById("demo1"); var tab2=document.getElementById("demo2"); tab2.innerHTML=tab1.innerHTML; function Marquee(){ if(tab2.offsetWidth-tab.scrollLeft==0) tab.scrollLeft-=tab1.offsetWidth else{ tab.scrollLeft++; } } var MyMar=setInterval(Marquee,speed); tab.onmouseover=function() {clearInterval(MyMar)}; tab.onmouseout=function() {MyMar=setInterval (Marquee,speed)}; </script>
這里要注意的是:
scrollLeft代表頁面利用滾動條滾動到右側時,隱藏在滾動條左側的頁面的寬度。
offsetWidth 是對象的可見寬度,包滾動條等邊線,會隨窗口的顯示大小改變。
setInterval() 方法可按照指定的周期(以毫秒計)來調用函數(shù)或計算表達式。setInterval() 方法會不停地調用函數(shù),直到 clearInterval() 被調用或窗口被關閉。
明白了這個具體的實現(xiàn)就好理解了。
實現(xiàn)的原理是這樣的:首先將需要滾動的內容復制一份。當右側的div顯示的內容與左側影藏的內容寬度相同時將父容器左側影藏的內容顯示出來,這樣就實現(xiàn)了將左側影藏的內容顯示出來同時將右側內容重新隱藏。如果右側內容顯示的部分少于左側影藏的內容就繼續(xù)講父容器想左側移動,實現(xiàn)隱藏。其中有一點需要注意的是,由于這里是將兩張圖片同時放入左側,當右側顯示了一半時會將左側影藏的完全顯示出來,又因為右側顯示的內容與左側的左邊內容相同所以實現(xiàn)了循環(huán)滾動的效果。
這樣平滑的滾動就實現(xiàn)了。
以上就是本文的全部內容,希望對大家的學習有所幫助。
相關文章
javascript延時重復執(zhí)行函數(shù) lLoopRun.js
javascript延時重復執(zhí)行函數(shù) lLoopRun.js...2007-06-06Highcharts 多個Y軸動態(tài)刷新數(shù)據(jù)的實現(xiàn)代碼
下面小編就為大家?guī)硪黄狧ighcharts 多個Y軸動態(tài)刷新數(shù)據(jù)的實現(xiàn)代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05css+js實現(xiàn)部分區(qū)域高亮可編輯遮罩層
下面介紹我在項目中實現(xiàn)的方式,全屏遮罩,部分區(qū)域可操作,需要的朋友可以參考下2014-03-03javascript實現(xiàn)狀態(tài)欄文字首尾相接循環(huán)滾動的方法
這篇文章主要介紹了javascript實現(xiàn)狀態(tài)欄文字首尾相接循環(huán)滾動的方法,實例分析了javascript定時函數(shù)及頁面元素屬性操作的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07