jQuery可以製作出與Flash媲美的動畫效果,這點絕對毋庸置疑,本文將透過實例示範一個基於滑鼠滾輪驅動的圖片切換效果。
本例達到的效果:
滑鼠滾輪滾動時圖片進行切換。
支援鍵盤方向鍵實現圖片切換效果。
支援點擊圖片切換,支援點擊目前圖片連結。
進度條滑桿展示圖片圖片數量進度。
XHTML
<div class="demo"> <div id="imageflow"> <div id="基於jquery實現滑鼠滾輪驅動的圖片切換效果_jquery"><img src="/static/imghwm/default1.png" data-src="images/loader.gif" class="lazy" alt="基於jquery實現滑鼠滾輪驅動的圖片切換效果_jquery" /></div> <div id="captions"></div> <div id="images"> <img src="/static/imghwm/default1.png" data-src="images/s1.jpg" class="lazy" alt="image1" /> <img src="/static/imghwm/default1.png" data-src="images/s2.jpg" class="lazy" alt="image2" /> <img src="/static/imghwm/default1.png" data-src="images/s3.jpg" class="lazy" alt="image3" /> <img src="/static/imghwm/default1.png" data-src="images/s4.jpg" class="lazy" alt="image4" /> </div> <div id="scrollbar"> <div id="slider"></div> </div> </div> </div>
div.demo是最外面的一層,包含了整個滾動效果所需的所有元素。 #imageflow是必需的,且與其內部包含的元素的ID名稱不能修改,如確實要修改,就要先定義或直接修改JS代碼了。 #基於jquery實現滑鼠滾輪驅動的圖片切換效果_jquery用來裝載一個載入動畫的圖片,當然你也可以直接寫成"基於jquery實現滑鼠滾輪驅動的圖片切換效果_jquery"或其他文字。 #captions用來顯示圖片的標題。 #images放置所要滾動切換的圖片,數量不限。 #scrollbar就是展示圖片的進度條。 #slider是一個滑桿,當切換圖片時,滑桿會滑動到對應的位置,以顯示圖片數量的位置。
CSS
.demo { width:860px; height:300px; margin:20px auto; position:relative; background:#e8f5fe; overflow:hidden } #images { margin:20px 0 0 60px; width:860px } #images img { position:absolute; margin-top:-160px } #基於jquery實現滑鼠滾輪驅動的圖片切換效果_jquery { margin:0; color:#fff; text-align:center } #基於jquery實現滑鼠滾輪驅動的圖片切換效果_jquery img { position:ralative; margin:0 } #captions { position:relative; height:24px; line-height:24px; top:100px; left:320px; background:url(images/cap_bg.png) no-repeat center center; color:#fff; font-weight:bold; text-align:center; z-index:10000 } #scrollbar { position:relative; top:-100px; height:2px; z-index:10001 background:#abcd3a url(images/scroll.gif) repeat-x; } #slider { position:absolute; width:15px; height:4px; margin:-1px 0 0 -1px; background:url(images/bar.gif) no-repeat; z-index:10002 }
CSS是整個效果實現的關鍵部分,如果CSS控制不好,將不會得到你要的效果。
.demo設定了寬度和高度,並設定position:relative和overflow:hidden,目的是為了讓滑鼠滑輪滾動作用的範圍限制在.demo裡。 #images設定了margin值,並對內部的img設定了相對定位。 #captions設定了用來顯示圖片標題的樣式,注意我使用半透明的圖片cap_bg.png作為背景圖片,在IE6下不支援透明的png圖片,所以你要進行相關的處理。接下來看滾動進度條和滑桿的設置,都運用的定位和深度設置,為何要這樣設置,只有大家去慢慢測試才會知道其中的奧妙。
引入jquery庫和滑動js檔案
<script type="text/javascript" src="js/jquery.js"></script> <script type="text/javascript" src="js/imageflow.js"></script>
所有的js動作都在imageflow.js完成,我只做了略微的改動,大家可以直接使用。
現在可以看到效果了吧。但還有問題:
圖片連接位址如何取得?
最終的效果應該是點擊目前展示的圖片時,會連接到一個頁面,用來展示該圖片相關的詳細資訊。那麼這個連結位址如何獲取,大概在第252行開始有這樣兩行程式碼:
image.url = image.getAttribute("longdesc"); image.ondblclick = function() { document.location = this.url; }
可以看出,圖片的連結位址來自它的屬性:longdesc,當點擊圖片的時候,頁面將會跳到對應的地址頁面。好現在我們回到剛開始的XHTML程式碼,只需給每張圖片指定longdesc屬性,並將值設為對應的網頁位址。如:
<img src="/static/imghwm/default1.png" data-src="images/s1.jpg" class="lazy" alt="image1" longdesc="#" />
現在,任務算是完成了。看完本例你會發現,你根本不需要些一句jquery程式碼,因為imageflow都已經完成了所有的操作程式碼。
以上就是本文的全部內容,希望對大家的學習有所幫助。

JavaScript是現代網站的核心,因為它增強了網頁的交互性和動態性。 1)它允許在不刷新頁面的情況下改變內容,2)通過DOMAPI操作網頁,3)支持複雜的交互效果如動畫和拖放,4)優化性能和最佳實踐提高用戶體驗。

C 和JavaScript通過WebAssembly實現互操作性。 1)C 代碼編譯成WebAssembly模塊,引入到JavaScript環境中,增強計算能力。 2)在遊戲開發中,C 處理物理引擎和圖形渲染,JavaScript負責遊戲邏輯和用戶界面。

JavaScript在網站、移動應用、桌面應用和服務器端編程中均有廣泛應用。 1)在網站開發中,JavaScript與HTML、CSS一起操作DOM,實現動態效果,並支持如jQuery、React等框架。 2)通過ReactNative和Ionic,JavaScript用於開發跨平台移動應用。 3)Electron框架使JavaScript能構建桌面應用。 4)Node.js讓JavaScript在服務器端運行,支持高並發請求。

Python更適合數據科學和自動化,JavaScript更適合前端和全棧開發。 1.Python在數據科學和機器學習中表現出色,使用NumPy、Pandas等庫進行數據處理和建模。 2.Python在自動化和腳本編寫方面簡潔高效。 3.JavaScript在前端開發中不可或缺,用於構建動態網頁和單頁面應用。 4.JavaScript通過Node.js在後端開發中發揮作用,支持全棧開發。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。1)C 用于解析JavaScript源码并生成抽象语法树。2)C 负责生成和执行字节码。3)C 实现JIT编译器,在运行时优化和编译热点代码,显著提高JavaScript的执行效率。

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。

JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)