JS實現(xiàn)圖片的不間斷連續(xù)滾動

bug修復(fù)版2017.07.11

js替代marquee實現(xiàn)圖片無縫滾動
可能大家都碰到過和措,當(dāng)marquee中滾動的是圖片的時候庄呈,滾到終點的時候直接就跳回到起點了,而不像文字那樣可以無縫滾動派阱,下面介紹的是通過js來實現(xiàn)圖片的無縫滾動诬留。
先了解一下下面這幾個屬性:
innerHTML: 設(shè)置或獲取位于對象起始和結(jié)束標(biāo)簽內(nèi)的 HTML
scrollHeight: 獲取對象的滾動高度。
scrollLeft: 設(shè)置或獲取位于對象左邊界和窗口中目前可見內(nèi)容的最左端之間的距離
scrollTop: 設(shè)置或獲取位于對象最頂端和窗口中可見內(nèi)容的最頂端之間的距離
scrollWidth: 獲取對象的滾動寬度
offsetHeight: 獲取對象相對于版面或由父坐標(biāo) offsetParent 屬性指定的父坐標(biāo)的高度
offsetLeft: 獲取對象相對于版面或由 offsetParent 屬性指定的父坐標(biāo)的計算左側(cè)位置
offsetTop: 獲取對象相對于版面或由 offsetTop 屬性指定的父坐標(biāo)的計算頂端位置
offsetWidth: 獲取對象相對于版面或由父坐標(biāo) offsetParent 屬性指定的父坐標(biāo)的寬度


圖片向上無縫滾動

<style type="text/css">

</style>
向上滾動
<div id="demo">
<div id="demo1">


圖片向上無縫滾動

</div>
<div id="demo2"></div>
</div>
<script>
var speed=10; //數(shù)字越大速度越慢
var tab=document.getElementById("demo");
var tab1=document.getElementById("demo1");
var tab2=document.getElementById("demo2");
tab2.innerHTML=tab1.innerHTML; //克隆demo1為demo2
function Marquee(){
if(tab2.offsetTop-tab.scrollTop<=0)//當(dāng)滾動至demo1與demo2交界時
tab.scrollTop-=tab1.offsetHeight //demo跳到最頂端
else{
tab.scrollTop++
}
}
var MyMar=setInterval(Marquee,speed);
tab.onmouseover=function() {clearInterval(MyMar)};//鼠標(biāo)移上時清除定時器達到滾動停止的目的
tab.onmouseout=function() {MyMar=setInterval(Marquee,speed)};//鼠標(biāo)移開時重設(shè)定時器
</script>


圖片向下無縫滾動

<style type="text/css">
#demo {
background: #FFF;
overflow:hidden;
border: 1px dashed #CCC;
height: 100px;
text-align: center;
float: left;
}
#demo img {
border: 3px solid #F2F2F2;
display: block;
}
</style>
向下滾動
<div id="demo">
<div id="demo1">


圖片向下無縫滾動

</div>
<div id="demo2"></div>
</div>

<script>
var speed=10; //數(shù)字越大速度越慢
var tab=document.getElementById("demo");
var tab1=document.getElementById("demo1");
var tab2=document.getElementById("demo2");
tab2.innerHTML=tab1.innerHTML; //克隆demo1為demo2
tab.scrollTop=tab.scrollHeight
function Marquee(){
if(tab1.offsetTop-tab.scrollTop>=0)//當(dāng)滾動至demo1與demo2交界時
tab.scrollTop+=tab2.offsetHeight //demo跳到最頂端
else{
tab.scrollTop--
}
}
var MyMar=setInterval(Marquee,speed);
tab.onmouseover=function() {clearInterval(MyMar)};//鼠標(biāo)移上時清除定時器達到滾動停止的目的
tab.onmouseout=function() {MyMar=setInterval(Marquee,speed)};//鼠標(biāo)移開時重設(shè)定時器
</script>


圖片向左無縫滾動

<style type="text/css">
#demo {
background: #FFF;
overflow:hidden;
border: 1px dashed #CCC;
width: 500px;
}
#demo img {
border: 3px solid #F2F2F2;
}
#indemo {
float: left;
width: 800%;
}
#demo1 {
float: left;
}
#demo2 {
float: left;
}
</style>
向左滾動
<div id="demo">
<div id="indemo">
<div id="demo1">

向左滾動

</div>
<div id="demo2"></div>
</div>
</div>

<script>
var speed=10; //數(shù)字越大速度越慢
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>


圖片向右無縫滾動

<style type="text/css">
#demo {
background: #FFF;
overflow:hidden;
border: 1px dashed #CCC;
width: 500px;
}
#demo img {
border: 3px solid #F2F2F2;
}
#indemo {
float: left;
width: 800%;
}
#demo1 {
float: left;
}
#demo2 {
float: left;
}
</style>
向右滾動
<div id="demo">
<div id="indemo">
<div id="demo1">


向右滾動

</div>
<div id="demo2"></div>
</div>
</div>

<script>
var speed=10; //數(shù)字越大速度越慢
var tab=document.getElementById("demo");
var tab1=document.getElementById("demo1");
var tab2=document.getElementById("demo2");
tab2.innerHTML=tab1.innerHTML;
function Marquee(){
if(tab.scrollLeft<=0)
tab.scrollLeft+=tab2.offsetWidth
else{
tab.scrollLeft--;
}
}
var MyMar=setInterval(Marquee,speed);
tab.onmouseover=function() {clearInterval(MyMar)};
tab.onmouseout=function() {MyMar=setInterval(Marquee,speed)};
</script>


最后贫母,如果有人想一個頁面有兩個滾動圖片集文兑,一個往左一個往右,那下面的能用了腺劣。我把js都加個i了绿贞,還有css


向右滾動
<div id="demoi">
<div id="indemoi">
<div id="demoi1">


向右滾動

</div>
<div id="demoi2"></div>
</div>
</div>

<script>
var speedi=10; //數(shù)字越大速度越慢
var tabi=document.getElementById("demoi");
var tabi1=document.getElementById("demoi1");
var tabi2=document.getElementById("demoi2");
tabi2.innerHTML=tabi1.innerHTML;
function Marqueei(){
if(tabi.scrollLeft<=0)
tabi.scrollLeft+=tabi2.offsetWidth
else{
tabi.scrollLeft--;
}
}
var MyMari=setInterval(Marqueei,speedi);
tabi.onmouseover=function() {clearInterval(MyMari)};
tabi.onmouseout=function() {MyMari=setInterval(Marqueei,speedi)};
</script>
來自:http://hi.baidu.com/psxiep/blog/item/5aa0890ac438b60e94ca6b78.html

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市誓酒,隨后出現(xiàn)的幾起案子樟蠕,更是在濱河造成了極大的恐慌,老刑警劉巖靠柑,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件寨辩,死亡現(xiàn)場離奇詭異,居然都是意外死亡歼冰,警方通過查閱死者的電腦和手機靡狞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來隔嫡,“玉大人甸怕,你說我怎么就攤上這事甘穿。” “怎么了梢杭?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵温兼,是天一觀的道長。 經(jīng)常有香客問我武契,道長募判,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任咒唆,我火速辦了婚禮届垫,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘全释。我一直安慰自己装处,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布浸船。 她就那樣靜靜地躺著妄迁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪糟袁。 梳的紋絲不亂的頭發(fā)上判族,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天躺盛,我揣著相機與錄音项戴,去河邊找鬼。 笑死槽惫,一個胖子當(dāng)著我的面吹牛周叮,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播界斜,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼仿耽,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了各薇?” 一聲冷哼從身側(cè)響起项贺,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎峭判,沒想到半個月后开缎,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡林螃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年奕删,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片疗认。...
    茶點故事閱讀 40,427評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡完残,死狀恐怖伏钠,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情谨设,我是刑警寧澤熟掂,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站扎拣,受9級特大地震影響打掘,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鹏秋,卻給世界環(huán)境...
    茶點故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一尊蚁、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧侣夷,春花似錦横朋、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至衙传,卻和暖如春决帖,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蓖捶。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工地回, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人俊鱼。 一個月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓刻像,卻偏偏與公主長得像,于是被迫代替她去往敵國和親并闲。 傳聞我的和親對象是個殘疾皇子细睡,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,440評論 2 359

推薦閱讀更多精彩內(nèi)容

  • 1. tab列表折疊效果 html: 能源系統(tǒng)事業(yè)部 崗位名稱: 工作地點 崗位名...
    lilyping閱讀 1,871評論 0 1
  • 我們首先要明白,我們給頁面添加效果用到的js到底是什么帝火?js其實包含三部分:dom 文檔對象模型 bom 瀏覽...
    一直以來都很好閱讀 807評論 0 0
  • 單例模式 適用場景:可能會在場景中使用到對象溜徙,但只有一個實例,加載時并不主動創(chuàng)建犀填,需要時才創(chuàng)建 最常見的單例模式蠢壹,...
    Obeing閱讀 2,076評論 1 10
  • 一、JS前言 (1)認識JS 也許你已經(jīng)了解HTML標(biāo)記(也稱為結(jié)構(gòu))宏浩,知道了CSS樣式(也稱為表示)知残,會使用HT...
    凜0_0閱讀 2,777評論 0 8
  • 健身房這個事物,于我而言最早只存在于電視劇和電影里,今年卻實實在在的走入我自己的平時生活中求妹。 現(xiàn)在年輕人平時消遣時...
    聆歌閱讀 602評論 0 2