国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

js實現圖片切換(動畫版)

2019-11-19 18:17:03
字體:
來源:轉載
供稿:網友

學習了妙味課堂的圖片切換(動畫版)

這個小效果相對簡單一點。

知識預備:

【1】background-position-x

background-position屬性設置背景原圖像(由 background-image 定義)的位置,意味著使用這個屬性的前提是必須設置背景原圖像background-image。

background-position有兩個屬性值, background-position:x | y,用法上可以對其一個屬性單獨使用 background-position-x 和 background-position-y。

準備工作完畢,開始寫代碼

第一步

由于這次需要的div很多,所以采用動態添加的方式,直接看代碼

<style> body{ margin: 0; background-color: #5e5e5e; } #box{ width: 857px; height: 574px; padding-top: 126px; padding-left:143px; background: url(img/bg.png) no-repeat; margin: 0px auto; } #wrap{ width: 700px; height: 420px; transform-style: preserve-3d; perspective: 800px; } #wrap div{ width: 10px; height: 420px; background: url(img/01.png) no-repeat; float: left; transition: .5s; } </style></head><body> <div id="box"> <div id="wrap"></div> </div> <script> //在wrap下,寫70個div,每個div顯示一張圖片的一小片部分,這樣70個div能完整的顯示出一張圖片 for(var i=0;i<70;i++){ str +='<div style="background-position-x:'+(-10*i)+'px"></div>'; } oWrap.innerHTML = str; //獲取70個div var divs = oWrap.getElementsByTagName('div');    </script> </body>

第二步

寫tab()函數,設置每個div要做的動畫

tab()函數

// 每個div設置前一個div的透明度為1,并且設置自己的透明度為0和背景圖片 function tab(n){ // 0  if(divs[n-1]){ divs[n-1].style.opacity = 1; } // 70 if(divs[n]){ divs[n].style.opacity = 0; divs[n].style.backgroundImage = "url(img/0"+imgNum+".png)"; } }

第三步

寫go()函數,利用定時器改變tab()函數的參數并且適時的改變背景圖片

go()

//給tab()函數傳遞n值 function go(){ timer = setInterval(function(){ tab(num); num++; //一張圖片切換完畢 if(num == 71){ clearInterval(timer); //切換下一張圖片 imgNum++; //num清0,動畫效果從第一個div開始 num = 0; //當切到最后一張圖片時,在從第一張開始切換 if(imgNum == 6){ imgNum = 1; } //切換完一張圖片時切換下一張圖片的間隔 setTimeout(go,800); } //div變換的速度 },80); }

總結:這個動畫效果實現起來簡單,代碼問題不大,主要就是實現思路的問題。

源碼:

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>圖片切換(動畫版)</title> <style> body{ margin: 0; background-color: #5e5e5e; } #box{ width: 857px; height: 574px; padding-top: 126px; padding-left:143px; background: url(img/bg.png) no-repeat; margin: 0px auto; } #wrap{ width: 700px; height: 420px; transform-style: preserve-3d; perspective: 800px; } #wrap div{ width: 10px; height: 420px; background: url(img/01.png) no-repeat; float: left; transition: .5s; } </style></head><body> <div id="box"> <div id="wrap"></div> </div> <script> //在wrap下,寫70個div,每個div顯示一張圖片的一小片部分,這樣70個div能完整的顯示出一張圖片 for(var i=0;i<70;i++){ str +='<div style="background-position-x:'+(-10*i)+'px"></div>'; } oWrap.innerHTML = str; //獲取70個div var divs = oWrap.getElementsByTagName('div'); go(); //給tab()函數傳遞n值 function go(){ timer = setInterval(function(){ tab(num); num++; //一張圖片切換完畢 if(num == 71){ clearInterval(timer); //切換下一張圖片 imgNum++; //num清0,動畫效果從第一個div開始 num = 0; //當切到最后一張圖片時,在從第一張開始切換 if(imgNum == 6){ imgNum = 1; } //切換完一張圖片時切換下一張圖片的間隔 setTimeout(go,800); } //div變換的速度 },80); } // 每個div設置前一個div的透明度為1,并且設置自己的透明度為0和背景圖片 function tab(n){ // 0  if(divs[n-1]){ divs[n-1].style.opacity = 1; } // 70 if(divs[n]){ divs[n].style.opacity = 0; divs[n].style.backgroundImage = "url(img/0"+imgNum+".png)"; } } </script></body></html>

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 东兰县| 盖州市| 安平县| 阳谷县| 吴忠市| 项城市| 宜春市| 读书| 乌兰察布市| 罗源县| 海南省| 朔州市| 长宁区| 城口县| 桂东县| 宜州市| 同江市| 曲水县| 唐山市| 金阳县| 子长县| 静海县| 石家庄市| 灵山县| 扎鲁特旗| 芦山县| 青海省| 凤城市| 尚义县| 肥东县| 大埔县| 大方县| 成都市| 当雄县| 莱西市| 瑞昌市| 思茅市| 深州市| 巨鹿县| 漳州市| 甘孜县|