這種效果在今後的web發展中是不是常用或者是否依然被設計師們所青睐,從技術層面看並不是最重要的,了解它的實現原理,對自身前端技術的提高,會有很大的幫助,世間萬物,萬變不離其宗,掌握了它的運行規律,你才不會被其花花外表所迷惑,甚至你可以在掌握其規律的前提下,運行相關技術,創造出新的效果來。下面看看它的實現過程:
1.html
復制代碼 代碼如下:
<div class="box" id="marqueebox0">
<ul>
<li style="background:#f8e2ac;">第一行</li>
<li style="background:#f5f5f5;">第二行</li>
<li style="background:#ffe6ec;">第三行</li>
</ul>
</div>
2.css 復制代碼 代碼如下:
.box{
width:150px;
height:25px;
line-height:25px;
border:#bbb 1px solid;
overflow:hidden;
}
.box ul{margin:0; padding:0}
.box li{
height:25px;
line-height:25px;
font-size:12px;
text-align:center;
list-style-type:none;
}
3.js 復制代碼 代碼如下:
function startmarquee(lh,speed,delay,index){
/*
函數startmarquee的參數:
lh:文字一次向上滾動的距離或高度;
speed:滾動速度;
delay:滾動停頓的時間間隔;
index:可以使封裝後的函數應用於頁面當中不同的元素;
*/
var t;
var p=false;
var o=document.getElementById("marqueebox"+index);
//獲取文檔中的滾動區域對象,賦值給變量o;
o.innerHTML+=o.innerHTML; //對象中的實際內容被復制了一份,包含了兩個ul,當然li標簽也
由原來的3行,變為6行;復制的目的在於給文字不間斷向上滾動提供過渡。
o.onmouseover=function(){p=true}
//鼠標滑過,停止滾動;
o.onmouseout=function(){p=false}
//鼠標離開,開始滾動;p是true還是false直接影響到下面start()函數的執行;
o.scrollTop = 0;
//文字內容頂端與滾動區域頂端的距離,初始值為0;
function start(){
t=setInterval(scrolling,speed); //每隔一段時間,setInterval便會執行一次
scrolling函數;speed越大,滾動時間間隔越大,滾動速度越慢;
if(!p){ o.scrollTop += 1;}
//滾動停止或開始,取決於p傳來的布爾值;
}
function scrolling(){
if(o.scrollTop%lh!=0){
//如果不被整除,即一次上移的高度達不到lh,則內容會繼續往上滾動;
o.scrollTop += 1;
if(o.scrollTop>=o.scrollHeight/2) o.scrollTop = 0;
//對象o中的內容之前被復制了一次,所以它的滾動高度,其實是原來內容的兩倍高度;
當內容向上滾動到scrollHeight/2的高度時,全部3行文字已經顯示了一遍,至此整塊內容
scrollTop歸0;再等待下一輪的滾動,從而達到文字不間斷向上滾動的效果;
}else{
clearInterval(t);
//否則清除t,暫停滾動
setTimeout(start,delay);
//經過delay間隔後,啟動start() 再連續滾動
}
}
setTimeout(start,delay);
//第一次啟動滾動;setTimeout會在一定的時間後執行函數start(),且只執行一次
}
//傳遞參數
startmarquee(25,30,3000,0);
//帶停頓效果
startmarquee(25,40,0,1);
//不間斷連續
以下為全部代碼: [Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]