javascript實(shí)現(xiàn)平滑無縫滾動(dòng)
本文我們實(shí)現(xiàn)純JS方式的滾動(dòng)廣告效果,供大家參考,具體內(nèi)容如下
先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ì))來調(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)容顯示出來,這樣就實(shí)現(xiàn)了將左側(cè)影藏的內(nè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è)影藏的完全顯示出來,又因?yàn)橛覀?cè)顯示的內(nèi)容與左側(cè)的左邊內(nèi)容相同所以實(shí)現(xiàn)了循環(huán)滾動(dòng)的效果。
這樣平滑的滾動(dòng)就實(shí)現(xiàn)了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
相關(guān)文章
javascript延時(shí)重復(fù)執(zhí)行函數(shù) lLoopRun.js
javascript延時(shí)重復(fù)執(zhí)行函數(shù) lLoopRun.js...2007-06-06
針對(duì)JavaScript中this指向的簡(jiǎn)單理解
這篇文章主要為大家詳細(xì)JavaScript中this指向的簡(jiǎn)單理解,感興趣的小伙伴們可以參考一下2016-08-08
Highcharts 多個(gè)Y軸動(dòng)態(tài)刷新數(shù)據(jù)的實(shí)現(xiàn)代碼
下面小編就為大家?guī)硪黄狧ighcharts 多個(gè)Y軸動(dòng)態(tài)刷新數(shù)據(jù)的實(shí)現(xiàn)代碼。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05
css+js實(shí)現(xiàn)部分區(qū)域高亮可編輯遮罩層
下面介紹我在項(xiàng)目中實(shí)現(xiàn)的方式,全屏遮罩,部分區(qū)域可操作,需要的朋友可以參考下2014-03-03
JavaScript實(shí)現(xiàn)復(fù)制內(nèi)容到粘貼板代碼
最近做了一個(gè)前端項(xiàng)目,其中有需求:通過button直接把input或者textarea里的值復(fù)制到粘貼板里。下面小編給大家分享JavaScript實(shí)現(xiàn)復(fù)制內(nèi)容到粘貼板代碼,需要的朋友參考下2016-03-03
javascript實(shí)現(xiàn)狀態(tài)欄文字首尾相接循環(huán)滾動(dòng)的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)狀態(tài)欄文字首尾相接循環(huán)滾動(dòng)的方法,實(shí)例分析了javascript定時(shí)函數(shù)及頁(yè)面元素屬性操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07

