本文實例為大家分享了js實現移動端輪播圖效果的具體代碼,供大家參考,具體內容如下
插件使用:
1.zepto.js
2.touch.js
實現效果
html部分:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
<!-- 結構 --> <!-- li*6>a[href=#]>img[src=./images/$.jpg] --> < div class = "box" > < ul > <!-- 為了無縫連接,我們在圖片這里前后增加了2個圖片 --> < li > < a href = "#" >< img src = "./images/6.jpg" alt = "" ></ a > </ li > < li > < a href = "#" >< img src = "./images/1.jpg" alt = "" ></ a > </ li > < li > < a href = "#" >< img src = "./images/2.jpg" alt = "" ></ a > </ li > < li > < a href = "#" >< img src = "./images/3.jpg" alt = "" ></ a > </ li > < li > < a href = "#" >< img src = "./images/4.jpg" alt = "" ></ a > </ li > < li > < a href = "#" >< img src = "./images/5.jpg" alt = "" ></ a > </ li > < li > < a href = "#" >< img src = "./images/6.jpg" alt = "" ></ a > </ li > < li > < a href = "#" >< img src = "./images/1.jpg" alt = "" ></ a > </ li > </ ul > </ div > |
css部分:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
* { margin : 0 ; padding : 0 ; } ul { list-style : none ; } .box { width : 100% ; overflow : hidden ; } ul { /* 把li變成8張之后,需要,把ul的寬度變寬 */ width : 800% ; /* transition: all 1s; */ } li { float : left ; width : 12.5% ; } img { width : 100% ; } |
js部分:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
//獲取DOM var box = $( ".box" ); var img = $( "ul img" ); var ul = $( "ul" ); var imgWidth = img.width(); var index = 1; var right = index * imgWidth; ul.css( "transform" , `translateX(-${right}px)`); setTimeout( function () { ul.css( "transition" , "all 500ms" ); }, 100); //往左滑,坐標在增大 box.on( "swipeLeft" , function () { index++; // if (index == img.length) { // index = 0; // } var left = index * imgWidth; ul.css( "transform" , `translateX(-${left}px)`); }); //往左滑,坐標在增大 box.on( "swipeRight" , function () { index--; // if (index == -1) { // index = img.length - 1; // } var right = index * imgWidth; ul.css( "transform" , `translateX(-${right}px)`); }); //過渡結束之后時進行 ul.on( "transitionend" , function () { //1.判讀 index //往左面滑(滑倒倒數第一張的時候,其實顯示的已經是用戶想看的第一張) if (index == img.length - 1) { index = 1; //index修改完畢之后需要重新執行一遍 var right = index * imgWidth; ul.css( "transform" , `translateX(-${right}px)`); //2.取消過渡效果 ul.css( "transition" , "none" ); //3.已經判斷完畢了,重新打開過渡效果 //這里設置一個1毫秒的延遲,否則會一起進行 setTimeout( function () { ul.css( "transition" , "all 500ms" ); }, 1); } //1.判讀 index //往右面滑(滑倒index為0的時候,顯示的是客戶想看的第6張圖) if (index == 0) { //2.取消過渡效果 ul.css( "transition" , "none" ); index = img.length - 2; //index修改完畢之后需要重新執行一遍 var left = index * imgWidth; ul.css( "transform" , `translateX(-${left}px)`); //延遲開啟過渡效果 setTimeout( function () { ul.css( "transition" , "all 500ms" ); }, 1) } }) |
代碼目前就分享到這里,歡迎大家有問題積極評論。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:https://blog.csdn.net/qq_15198465/article/details/99354857