原生javascript實現的水平圖片無縫滾動效果

来源:http://www.cnblogs.com/nulifendou/archive/2016/02/11/5186568.html
-Advertisement-
Play Games

原生javascript實現的水平圖片無縫滾動效果:圖片水平無縫滾動效果在大量的網站都有應用,特別是一些企業網站在展示產品的時候,因為是動態效果,所以能夠給網站增色不少,相比靜態圖片展示更能夠吸引用戶的註意力,下麵就通過實例代碼介紹一下如何實現此效果。代碼如下: <!DOCTYPE html> <h


原生javascript實現的水平圖片無縫滾動效果:
圖片水平無縫滾動效果在大量的網站都有應用,特別是一些企業網站在展示產品的時候,因為是動態效果,所以能夠給網站增色不少,相比靜態圖片展示更能夠吸引用戶的註意力,下麵就通過實例代碼介紹一下如何實現此效果。
代碼如下:

<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css"> 
#demo{ 
  background:#FFF; 
  overflow:hidden; 
  border:1px dashed #CCC; 
  width:500px; 
} 
#indemo{
  float:left;
  width:2000px;
} 
#indemo a{
  width:100px;
  height:100px;
  float:left;
  background-color:blue;
  margin-left:5px;
  text-align:center;
  line-height:100px;
  color:red;
  text-decoration:none;
}
#demo1{float:left;} 
#demo2{float:left;} 
</style>
<script type="text/javascript"> 
window.onload=function(){
  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>
</head>
<body>
<div id="demo">
  <div id="indemo">
    <div id="demo1"> 
      <a href="#">螞蟻部落一</a> 
      <a href="#">螞蟻部落二</a> 
      <a href="#">螞蟻部落三</a> 
      <a href="#">螞蟻部落四</a> 
      <a href="#">螞蟻部落五</a> 
      <a href="#">螞蟻部落六</a> 
    </div>
    <div id="demo2"></div>
  </div>
</div>
</body>
</html>

以上代碼實現了我們要求,為了掩飾方便,將圖片替換為文字,實際應用中,只要稍加修改就可以了,代碼很簡單,但是對於初學者來說可能就有點麻煩,下麵就對它做一下註釋。
一.代碼註釋:
1.window.onload=function(){},當文檔內容完全載入完畢再去執行函數中的代碼。
2.var speed=10,設置滾動的速度,值越小速度越快。
3.var tab=document.getElementById("demo"),根據id屬性值獲取對象。
4.tab2.innerHTML=tab1.innerHTML,複製一份內容給tab2.
5.function Marquee(){},此函數是滾動的核心實現。
6.if(tab2.offsetWidth-tab.scrollLeft<=0){tab.scrollLeft-=tab1.offsetWidth } ,判斷向左滾動的尺寸是否小於等於tab2或者tab1的寬度,如果小於等於,則說明一個完整的圖片隊列滾動完畢,這個時候是tab2的接續在tab1的後面,這個時候重新設置tab.scrollLeft為0,也就是重新開始滾動,這樣就實現了無縫滾動效果。
二.相關閱讀:
1.innerHTML屬性可以參閱js的innerHTML屬性的用法一章節。 
2.offsetWidth屬性可以參閱scrollTop、offsetHeight和offsetTop等屬性用法詳解一章節。 
3.scrollLeft屬性可以參閱offsetLeft、clientLeft和scrollLeft等屬性的用法一章節。 
4.setInterval()函數可以參閱setInterval()函數用法詳解一章節。
5.clearInterval()函數可以參閱window對象的clearInterval()方法一章節。  

原文地址是:http://www.softwhy.com/forum.php?mod=viewthread&tid=11997

更多內容可以參閱:http://www.softwhy.com/javascript/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • css如何匹配第幾個li元素並設置樣式:如果有一個li元素列表,如果想設置指定位置li的樣式。這個在以前可能需要稍微麻煩一些,比如在這個要設置的li元素上添加一個class或者id之類。但是上面的方式不夠靈活,下麵介紹一下如何通過偽類選擇器實現此功能。代碼實例: <!DOCTYPE html> <h
  • jquery實現的選項卡的嵌套代碼實例:關於選項卡功能大家一定都不會陌生,無非就是滑鼠點擊或者懸浮能夠切換相關的內容。通常情況下,大家見到的選項卡都是沒有嵌套功能的,也就是說就是完成了一層切換效果,本章節分享一段代碼實例,實現了選項卡的嵌套功能,也就是選項卡中嵌套有選項卡功能,也就能夠容納更多的內容
  • 點擊刪除彈出提示是否刪除代碼:在一些應用中,會有刪除功能,比如刪除新聞等功能,在這些功能中,當點擊刪除的時候,一般會彈出提示視窗,提示是否要刪除指定的內容,以防止出現誤操作現象,下麵就通過代碼實例介紹一下,如何彈出這個提示視窗。代碼實例如下: <!DOCTYPE html> <html> <head
  • 使用box-shadow屬性實現圓角效果代碼實例:通常實現圓角效果我們使用border-radius,其實我們也可以使用box-shadow屬性來實現。兩個屬性的具體用法這裡就不多介紹了,具體可以參閱以下兩個文章:(1).圓角效果可以參閱CSS3實現圓角效果一章節。(2).box-shadow可以參
  • 利用jquery實現的批量設置指定type類型input標簽的樣式:input標簽具有多種類型,如果input標簽眾多的話,並且需要動態的設置它們的樣式,那麼使用jquery將是一個良好的選擇。代碼實例: $("input[type=text]").each(function(){ $(this).
  • 點擊彈出居中帶有透明遮罩層視窗:本章節介紹一下如何點擊一個按鈕實現彈出一個居中視窗,並且此視窗帶有半透明的遮罩層效果,此效果在當下比較流行,當然還有更為複雜的實現方式,當然效果也更為絢麗,下麵介紹的代碼能夠簡單實現此效果。代碼如下: <!DOCTYPE html> <html> <head> <me
  • box-shadow並不會增加元素的實際占據空間:關於此屬性的用法這裡就不多做介紹了,具體可以參閱CSS3的box-shadow屬性用法詳解一章節。對元素引用此屬性之後,元素在外觀上是看起來體積變大了,其實並沒有更多的占據空間。代碼實例如下: <!DOCTYPE html> <html> <head
  • jquery實現的豎向動態柱狀條效果:很多數據統計效果中,柱狀條方式的算是比較常見的一種,形象直觀,下麵就是一段能夠實現此功能的代碼實例,並且具有一定的動態效果,下麵就對代碼做一下分享,並詳細介紹一下它的實現過程。代碼如下: <!DOCTYPE html> <html> <head> <meta c
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...