1 <div id="review_box"> 2 <ul id="comment1"> 3 <li>第一條</li> 4 <li>第二條</li> 5 <li>第三條</li> 6 <li>第四條</li> 7 <li>第五條</li> 8 <li>第六條</li> 9 </ul> 10 <ul id="comment2"></ul> 11 </div>
CSS:
1 * { 2 margin: 0; 3 padding: 0; 4 } 5 div { 6 width: 100px; 7 height: 63px; /* 必須 */ 8 overflow: hidden;/* 必須 */ 9 margin: 50px auto; 10 border: 1px solid red; 11 text-align: center; 12 } 13 ul { 14 list-style: none; 15 }
JavaScript:
1 window.onload = roll(50); 2 3 function roll(t) { 4 var ul1 = document.getElementById("comment1"); 5 var ul2 = document.getElementById("comment2"); 6 var ulbox = document.getElementById("review_box"); 7 ul2.innerHTML = ul1.innerHTML; 8 ulbox.scrollTop = 0; // 開始無滾動時設為0 9 var timer = setInterval(rollStart, t); // 設置定時器,參數t用在這為間隔時間(單位毫秒),參數t越小,滾動速度越快 10 // 鼠標移入div時暫停滾動 11 ulbox.onmouseover = function () { 12 clearInterval(timer); 13 } 14 // 鼠標移出div后繼續滾動 15 ulbox.onmouseout = function () { 16 timer = setInterval(rollStart, t); 17 } 18 } 19 20 // 開始滾動函數 21 function rollStart() { 22 // 上面聲明的DOM對象為局部對象需要再次聲明 23 var ul1 = document.getElementById("comment1"); 24 var ul2 = document.getElementById("comment2"); 25 var ulbox = document.getElementById("review_box"); 26 // 正常滾動不斷給scrollTop的值+1,當滾動高度大於列表內容高度時恢復為0 27 if (ulbox.scrollTop >= ul1.scrollHeight) { 28 ulbox.scrollTop = 0; 29 } else { 30 ulbox.scrollTop++; 31 } 32 }
*有錯誤的地方歡迎指正
*轉載請注明出處