国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript實現平滑無縫滾動

2019-11-20 10:08:54
字體:
來源:轉載
供稿:網友

本文我們實現純JS方式的滾動廣告效果,供大家參考,具體內容如下

先show一下成品:

首先是網頁樣式:

#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實現:

<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.offsetWidthelse{ tab.scrollLeft++; }}var MyMar=setInterval(Marquee,speed);tab.onmouseover=function() {clearInterval(MyMar)};tab.onmouseout=function() {MyMar=setInterval(Marquee,speed)};</script>

這里要注意的是:

scrollLeft代表頁面利用滾動條滾動到右側時,隱藏在滾動條左側的頁面的寬度。

offsetWidth 是對象的可見寬度,包滾動條等邊線,會隨窗口的顯示大小改變。

setInterval() 方法可按照指定的周期(以毫秒計)來調用函數或計算表達式。setInterval() 方法會不停地調用函數,直到 clearInterval() 被調用或窗口被關閉。

明白了這個具體的實現就好理解了。

實現的原理是這樣的:首先將需要滾動的內容復制一份。當右側的div顯示的內容與左側影藏的內容寬度相同時將父容器左側影藏的內容顯示出來,這樣就實現了將左側影藏的內容顯示出來同時將右側內容重新隱藏。如果右側內容顯示的部分少于左側影藏的內容就繼續講父容器想左側移動,實現隱藏。其中有一點需要注意的是,由于這里是將兩張圖片同時放入左側,當右側顯示了一半時會將左側影藏的完全顯示出來,又因為右側顯示的內容與左側的左邊內容相同所以實現了循環滾動的效果。

這樣平滑的滾動就實現了。

以上就是本文的全部內容,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沛县| 阿拉善右旗| 鄂温| 梁山县| 兴仁县| 昌乐县| 石泉县| 庆安县| 茶陵县| 阜南县| 南充市| 新宁县| 盐源县| 天峻县| 富锦市| 安阳县| 句容市| 乐都县| 巫溪县| 嘉鱼县| 灯塔市| 略阳县| 团风县| 屏山县| 三原县| 衢州市| 岳阳市| 南召县| 铁岭市| 博爱县| 水城县| 安阳县| 包头市| 湟源县| 浏阳市| 寿宁县| 百色市| 黔江区| 博湖县| 仙游县| 阳朔县|