JS平滑無(wú)縫滾動(dòng)效果的實(shí)現(xiàn)代碼
本文我們實(shí)現(xiàn)純JS方式的滾動(dòng)廣告效果。
先show一下成品:
首先是網(wǎng)頁(yè)樣式:
#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實(shí)現(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代表頁(yè)面利用滾動(dòng)條滾動(dòng)到右側(cè)時(shí),隱藏在滾動(dòng)條左側(cè)的頁(yè)面的寬度。
offsetWidth 是對(duì)象的可見寬度,包滾動(dòng)條等邊線,會(huì)隨窗口的顯示大小改變。
setInterval() 方法可按照指定的周期(以毫秒計(jì))來(lái)調(diào)用函數(shù)或計(jì)算表達(dá)式。setInterval() 方法會(huì)不停地調(diào)用函數(shù),直到 clearInterval() 被調(diào)用或窗口被關(guān)閉。
明白了這個(gè)具體的實(shí)現(xiàn)就好理解了。
實(shí)現(xiàn)的原理是這樣的:首先將需要滾動(dòng)的內(nèi)容復(fù)制一份。當(dāng)右側(cè)的div顯示的內(nèi)容與左側(cè)影藏的內(nèi)容寬度相同時(shí)將父容器左側(cè)影藏的內(nèi)容顯示出來(lái),這樣就實(shí)現(xiàn)了將左側(cè)影藏的內(nèi)容顯示出來(lái)同時(shí)將右側(cè)內(nèi)容重新隱藏。如果右側(cè)內(nèi)容顯示的部分少于左側(cè)影藏的內(nèi)容就繼續(xù)講父容器想左側(cè)移動(dòng),實(shí)現(xiàn)影藏。其中有一點(diǎn)需要注意的是,由于這里是將兩張圖片同時(shí)放入左側(cè),當(dāng)右側(cè)顯示了一半時(shí)會(huì)將左側(cè)影藏的完全顯示出來(lái),又因?yàn)橛覀?cè)顯示的內(nèi)容與左側(cè)的左邊內(nèi)容相同所以實(shí)現(xiàn)了循環(huán)滾動(dòng)的效果。
這樣平滑的滾動(dòng)就實(shí)現(xiàn)了。
以上這篇JS平滑無(wú)縫滾動(dòng)效果的實(shí)現(xiàn)代碼就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- JavaScript實(shí)現(xiàn)垂直向上無(wú)縫滾動(dòng)特效代碼
- javascript實(shí)現(xiàn)的上下無(wú)縫滾動(dòng)效果
- javascript實(shí)現(xiàn)的左右無(wú)縫滾動(dòng)效果
- angularjs實(shí)現(xiàn)文字上下無(wú)縫滾動(dòng)特效代碼
- 標(biāo)準(zhǔn)的js無(wú)縫滾動(dòng)效果
- JS簡(jiǎn)單實(shí)現(xiàn)無(wú)縫滾動(dòng)效果實(shí)例
- js實(shí)現(xiàn)可控制左右方向的無(wú)縫滾動(dòng)效果
- JQuery插件Marquee.js實(shí)現(xiàn)無(wú)縫滾動(dòng)效果
- JS實(shí)現(xiàn)的N多簡(jiǎn)單無(wú)縫滾動(dòng)代碼(包含圖文效果)
- Javascript 實(shí)現(xiàn)圖片無(wú)縫滾動(dòng)
- js向上無(wú)縫滾動(dòng),網(wǎng)站公告效果 具體代碼
- JS無(wú)縫滾動(dòng)效果實(shí)現(xiàn)方法分析
相關(guān)文章
使用JS組件實(shí)現(xiàn)帶ToolTip驗(yàn)證框的實(shí)例代碼
這篇文章主要介紹了使用JS組件實(shí)現(xiàn)帶ToolTip驗(yàn)證框的實(shí)例代碼,需要的朋友可以參考下2017-08-08JS實(shí)現(xiàn)超過(guò)長(zhǎng)度限制后自動(dòng)跳轉(zhuǎn)下一款文本框的方法
這篇文章主要介紹了JS實(shí)現(xiàn)超過(guò)長(zhǎng)度限制后自動(dòng)跳轉(zhuǎn)下一款文本框的方法,涉及javascript操作字符及本文框的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02詳解如何在微信小程序開發(fā)中正確的使用vant ui組件
這篇文章主要介紹了詳解如何在微信小程序開發(fā)中正確的使用vant ui組件,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09bootstrap datepicker限定可選時(shí)間范圍實(shí)現(xiàn)方法
這篇文章主要介紹了bootstrap datepicker限定可選時(shí)間范圍的實(shí)現(xiàn)方法,本文涉及到相關(guān)知識(shí)點(diǎn),通過(guò)實(shí)例給大家介紹的非常詳細(xì),需要的朋友可以參考下2016-09-09JS數(shù)組實(shí)現(xiàn)分類統(tǒng)計(jì)實(shí)例代碼
本文通過(guò)實(shí)例代碼給大家介紹了js數(shù)組實(shí)現(xiàn)分類統(tǒng)計(jì)的相關(guān)知識(shí),非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09css+js實(shí)現(xiàn)部分區(qū)域高亮可編輯遮罩層
下面介紹我在項(xiàng)目中實(shí)現(xiàn)的方式,全屏遮罩,部分區(qū)域可操作,需要的朋友可以參考下2014-03-03