jquery+css實(shí)現(xiàn)動(dòng)感的圖片切換效果
本文實(shí)例講述了jquery+css實(shí)現(xiàn)動(dòng)感的圖片切換效果代碼。分享給大家供大家參考。具體如下:
運(yùn)行效果截圖如下:
具體代碼如下:
基本思路:定義一個(gè)數(shù)組存放需要展示的圖片,接著當(dāng)單擊圖片時(shí)刪除zoomIn類,添加fadeOutRight類,實(shí)現(xiàn)實(shí)圖右移并消失,記數(shù)器加1(用于調(diào)用下一張圖片),當(dāng)圖片刪除500毫秒后判斷圖片是不是最后一張,如果是,就把記數(shù)器調(diào)為0,從第一張圖片開始,刪除圖片代碼,接著創(chuàng)建一張新的圖片代碼,并把src設(shè)為下一張圖片,同時(shí)加上縮放動(dòng)畫樣式類animated zoomIn,讓圖片實(shí)現(xiàn)動(dòng)畫顯示,之后把新建的圖片代碼插上p元素之前。
首選引入CSS動(dòng)畫文件與jquery庫(kù)
<link rel="stylesheet" href="css/animate.min.css"/> <script type="text/javascript" src="js/jquery/1.11.1/jquery.min.js"></script>
構(gòu)建簡(jiǎn)單的html
<div class="container"> <div class="center animated"> <h1>Image Animation with A Single Img, CSS3 & some jQuery</h1> <img class="animated" src="images/island_1x.png" alt=""/> <p> <a target="_blank" href="#">腳本之家</a>, </p> </div> </div>
再加上一些CSS,這里隨意,請(qǐng)根據(jù)自己的項(xiàng)目來(lái)調(diào)整
.container { width: 100vw; height: 100vh; background-color: #fff; position: absolute; } .center { width: 600px; margin-left: auto; margin-right: auto; position: relative; top: 50%; transform: translateY(-50%); text-align: center; background-image: url(images/banana.png); background-position: -10000px,-10000px; background-repeat: no-repeat; } .center h1 { margin: 0px; padding: 0px; text-align: center; margin-bottom: 50px; font-size: 18px; text-transform: uppercase; } .center p{ padding-top:50px; text-align: center; color: #ccc; font-size: 12px; } .center p a{ text-decoration: none; color: inherit; } .center p a:hover{ color:#222; } .center img{ cursor: pointer; }
基本的CSS定位整個(gè)頁(yè)面,動(dòng)畫不受以上的CSS影響。
寫入JS實(shí)現(xiàn)動(dòng)畫效要
var imgs=[ //定義存放圖片路徑的數(shù)組 "images/island_1x.png", "images/banana.png", "images/rescued-illos_1x.png", "images/rivalry_1x.png", "images/sir_crags_a_lot_1x.png", "images/sf-cryptids_1x.png", "images/db_space_1x.png", "images/xmas1_1x.png" ]; var counter =0; //圖片的記數(shù)器 $(document).ready(function () { $(".center").on("click","img",function(){ //定義.center單擊圖片事件 $(this).removeClass("zoomIn").addClass("fadeOutRight"); //刪除單擊圖片的zoomIn類,添加fadeOutRight類 counter++; //記數(shù)器加1 setTimeout(function(){ //500毫秒后執(zhí)行此方法 if(counter==imgs.length) counter=0; //如果到了最后一張圖片則返回第一張 $(".center img").remove(); //刪除圖片 $("<img/>").attr("src",imgs[counter]).addClass("animated zoomIn").insertBefore($(".center p")); //拼接成下一張圖片并加上縮放動(dòng)畫樣式類animated zoomIn,最后添加上.center p元素前 if(imgs[counter+1]!=undefined) $(".center").css("backgroundImage","url("+imgs[counter+1]+")") //如果下一張圖片沒有定義,剛為.center元素的背影圖片改為下一張圖片(不明白加此行代碼的用意,感覺沒意義。。。) },500); }); });
源碼下載:jquery+css實(shí)現(xiàn)動(dòng)感的圖片切換效果源碼
以上就是jquery結(jié)合css實(shí)現(xiàn)動(dòng)感的圖片切換效果,分享的代碼很詳細(xì),還提供了代碼的基本思路,希望大家喜歡,并且可以學(xué)以致用。
相關(guān)文章
JQuery動(dòng)態(tài)生成的按鈕無(wú)法觸發(fā)問(wèn)題及完美解決方法
利用JQuery動(dòng)態(tài)添加的按鈕無(wú)法通過(guò)$(selector).click方法觸發(fā)點(diǎn)擊事件,下面小編給大家?guī)?lái)了JQuery動(dòng)態(tài)生成的按鈕無(wú)法觸發(fā)問(wèn)題與解決方法,需要的朋友可以參考下2023-02-02jquery實(shí)現(xiàn)簡(jiǎn)單的表單驗(yàn)證
這篇文章主要介紹了jquery實(shí)現(xiàn)簡(jiǎn)單的表單驗(yàn)證,思路大概是先為每一個(gè)required添加必填的標(biāo)記,用each()方法來(lái)實(shí)現(xiàn),感興趣的小伙伴們可以參考一下2015-11-11jQuery的寫法不同導(dǎo)致的兼容性問(wèn)題的解決方法
今天用jQuery操作table時(shí),出現(xiàn)了一個(gè)兼容性的問(wèn)題,以前都說(shuō)jQuery的兼容性是絕對(duì)可靠的,今天發(fā)現(xiàn)了這個(gè)bug!2010-07-07超級(jí)有用的13個(gè)基于jQuery的內(nèi)容滾動(dòng)插件和教程
這篇文章與大家分享13個(gè)超級(jí)有用的 jQuery 內(nèi)容滾動(dòng)插件和教程。您可能經(jīng)常能看到一些網(wǎng)站上特色區(qū)域的內(nèi)容以滾動(dòng)方式變化,這是一種在有限的網(wǎng)頁(yè)空間內(nèi)展示更多內(nèi)容的良好方式,而且能吸引用戶注意力。2011-07-07jQuery實(shí)現(xiàn)簡(jiǎn)單的滑動(dòng)導(dǎo)航代碼(移動(dòng)端)
這篇文章主要介紹了jQuery實(shí)現(xiàn)簡(jiǎn)單的滑動(dòng)導(dǎo)航代碼,適合用于移動(dòng)端。需要的朋友可以參考下2017-05-05jQuery中常用動(dòng)畫效果函數(shù)知識(shí)點(diǎn)整理
這篇文章我們給大家整理了關(guān)于jQuery中常用動(dòng)畫效果函數(shù)的相關(guān)知識(shí)點(diǎn)內(nèi)容,有興趣的朋友可以學(xué)習(xí)下。2018-08-08