功能描述:javascript
1.鼠標通過 左右側箭頭顯示,鼠標離開 箭頭隱藏css
2.動態添加底部小圓圈並綁定單擊事件,而且讓小圓圈的點擊事件和左右箭頭點擊事件同步java
3.拷貝第一張圖片添加到ul最後能夠實現動態添加圖片web
4.給箭頭綁定單擊事件,而且使圖片能夠無縫輪播app
5.實現自動輪播(動畫函數)函數
具體實現代碼:動畫
1.鼠標移入左右側箭頭顯示,鼠標離開箭頭隱藏this
1 con.addEventListener('mouseenter', function() { 2 arrow_l.style.display = 'block'; // 將左右箭頭的display設爲block 3 arrow_r.style.display = 'block'; 4 }); 5 con.addEventListener('mouseleave', function() { 6 arrow_l.style.display = 'none'; // 將左右箭頭display設爲none 7 arrow_r.style.display = 'none'; 8 });
2.動態添加底部小圓圈並綁定單擊事件,而且讓小圓圈的點擊事件和左右箭頭點擊事件同步spa
1 for(var i = 0; i < ul.children.length; i++) { 2 var li = document.createElement('li'); 3 li.setAttribute('index', i); // 經過添加自定義屬性來記錄小圓圈索引號 4 ol.appendChild(li); // 將建立的li添加進ol裏 5 // 生成小圓圈的同時就能夠給它綁定單擊事件 6 li.addEventListener('click', function() { 7 // 排他思想 幹掉全部人,留下我本身 8 for(var i = 0; i < ol.children.length; i++) { // 先把全部的小圓圈改成未選中狀態 9 ol.children[i].className = ''; 10 } 11 // 再把當前小圓圈改成選中狀態 12 this.className = 'current'; 13 var index = this.getAttribute('index'); // 獲取當前小圓圈的索引 14 // 將index值賦值給num以及circle,將小圓圈的點擊事件和左右箭頭點擊事件同步 15 num = index; 16 circle = index; 17 animate(ul, - index * conWidth); 18 }) 19 }
3.拷貝第一張圖片添加到ul最後能夠實現動態添加圖片code
1 // 克隆第一張圖片 2 var first = ul.children[0].cloneNode(true); // true 深拷貝 3 ul.appendChild(first); // 拷貝第一張圖片添加到ul最後
4.給箭頭綁定單擊事件,而且使圖片能夠無縫輪播
①右側箭頭的單擊事件
1 var num = 0; // 用來存儲點擊後圖片序號 2 var circle = 0; // 用來存儲點擊後小圓圈序號 3 var flag = true; // flag 節流閥 防止用戶點擊過快 圖片播放太快 4 // 右側箭頭點擊播放 5 arrow_r.addEventListener('click', function() { 6 if(flag) { 7 // 點擊後先關閉節流閥 8 flag = false; 9 // 若是播放到了最後一張,就把left直接值設爲0從頭播放,同時還原num 10 if(num == ul.children.length - 1) { 11 ul.style.left = 0; 12 num = 0; 13 } 14 num++; 15 animate(ul, - num * conWidth, function() { 16 // 回調函數 動畫執行完後開啓節流閥 17 flag = true; 18 }); 19 // 小圓圈和箭頭一塊兒變化 20 circle++; 21 /* if(circle == ol.children.length) { 22 circle = 0; 23 } */ 24 // 能夠用三元運算符判斷小圓圈是否到了最後一個,若是是最後一個就還原circle 25 circle == ol.children.length ? circle = 0 : circle; 26 circleChange(); // 使當前小圓圈爲選中狀態(重複代碼封裝到一個函數裏了) 27 } 28 })
②左側箭頭的單擊事件
1 arrow_l.addEventListener('click', function() { 2 if(flag) { 3 // 首先關閉節流閥 4 flag = false; 5 // 若是播放到了第一張,就把left值設爲最後一張的值 6 if(num == 0) { 7 num = ul.children.length - 1; 8 ul.style.left = - num * conWidth + 'px'; 9 } 10 num--; 11 animate(ul, - num * conWidth, function() { 12 flag = true; 13 }); 14 // 小圓圈和箭頭一塊兒變化 15 circle--; 16 // 三元表達式 circle < 0 時說明是第一張圖片,將小圓圈改成第四個(索引爲3) 17 circle < 0 ? circle = ol.children.length - 1 : circle; 18 circleChange(); 19 } 20 })
1 // 小圓圈的選中狀態(相同代碼能夠封裝爲一個函數,使代碼更簡潔) 2 function circleChange() { 3 // 排他思想 4 for(var i = 0; i < ol.children.length; i++) { 5 ol.children[i].className = ''; 6 } 7 ol.children[circle].className = 'current'; 8 }
5.實現自動輪播(動畫函數)
1 // 自動播放輪播圖,至關於隔一段時間調用一次右側箭頭點擊事件 2 var timer = setInterval(function() { 3 // 手動調用點擊事件 4 arrow_r.click(); 5 }, 2000);
動畫函數 animate.js(ps:我沒有把這個寫入下邊index.js裏,這個要你本身弄進去哦,能夠做爲animate.js文件引入進去或者直接粘貼到你的js代碼裏邊)
1 // obj 動畫對象 2 // target 目標位置 3 // callback 回調函數 4 function animate(obj, target, callback) { 5 clearInterval(obj.timer); 6 obj.timer = setInterval(function() { 7 var step = (target - obj.offsetLeft) / 10; // step步長值 8 step = step > 0 ? Math.ceil(step) : Math.floor(step); // 大於零向上取整,小於零向下取整 9 if(obj.offsetLeft == target) { 10 clearInterval(obj.timer); 11 // if(callback) { // 判斷是否傳了回調函數 12 // callback(); // 回調函數,當動畫執行完後才執行 13 // } 14 // &&是短路運算符,存在callback時纔會繼續執行callback() 15 callback && callback(); 16 } 17 obj.style.left = obj.offsetLeft + step + 'px'; 18 }, 15) 19 }
具體實現代碼以下:
HTML代碼:
1 <div class="con"> 2 <i class="icon iconfont iconarrow_left arrow-l"></i> 3 <i class="icon iconfont iconarrow_right arrow-r"></i> 4 <ul> 5 <li> 6 <a href="javascript:;"><img src="images/img1.jpg" alt=""></a> 7 </li> 8 <li> 9 <a href="javascript:;"><img src="images/img2.jpg" alt=""></a> 10 </li> 11 <li> 12 <a href="javascript:;"><img src="images/img3.jpg" alt=""></a> 13 </li> 14 <li> 15 <a href="javascript:;"><img src="images/img4.jpg" alt=""></a> 16 </li> 17 <li> 18 <a href="javascript:;"><img src="images/img5.jpg" alt=""></a> 19 </li> 20 </ul> 21 <ol> 22 </ol> 23 </div>
ps: 我左右側小箭頭是使用的Iconfont圖標(iconarrow_left,iconarrow_right),要引入進去
<link rel="stylesheet" href="http://at.alicdn.com/t/font_1518420_oljcm07nn2.css">
CSS代碼:
1 <style> 2 * { 3 margin: 0; 4 padding: 0; 5 } 6 ul,li,ol,a { 7 list-style: none; 8 text-decoration: none; 9 } 10 .con { 11 width: 533px; 12 height: 300px; 13 margin: 100px auto; 14 position: relative; 15 background-color: #f0f0f0; 16 overflow: hidden; 17 } 18 .arrow-l,.arrow-r{ 19 display: none; 20 width: 20px; 21 height: 40px; 22 line-height: 40px; 23 text-align: center; 24 color: #eee; 25 position: absolute; 26 top: 45%; 27 background-color: rgba(0, 0, 0, 0.2); 28 z-index: 2; 29 cursor: pointer; 30 } 31 .arrow-l { 32 left: 0; 33 } 34 .arrow-r{ 35 right: 0; 36 } 37 ul { 38 position: absolute; 39 width: 600%; 40 } 41 ul li { 42 float: left; 43 } 44 ul li img { 45 width: 533px; 46 height: 300px; 47 } 48 ol { 49 position: absolute; 50 left: 50%; 51 bottom: 8px; 52 -webkit-transform: translateX(-50%); 53 transform: translateX(-50%); 54 } 55 ol li { 56 float: left; 57 width: 6px; 58 height: 6px; 59 margin: 0 2px; 60 border-radius: 50%; 61 border: 2px solid rgba(255, 255, 255, 0.5); 62 cursor: pointer; 63 } 64 .current { 65 background-color: #ffe; 66 } 67 </style>
詳細JavaScript代碼(index.js)
1 window.addEventListener('load', function() { // 等頁面加載完畢 2 // 獲取須要用到的的元素 3 var arrow_l = document.querySelector('.arrow-l'); 4 var arrow_r = document.querySelector('.arrow-r'); 5 var con = document.querySelector('.con'); 6 var conWidth = con.offsetWidth; 7 // 鼠標通過箭頭顯示,鼠標離開箭頭隱藏 8 con.addEventListener('mouseenter', function() { 9 arrow_l.style.display = 'block'; // 將左右箭頭的display設爲block 10 arrow_r.style.display = 'block'; 11 // 鼠標通過中止定時器 12 clearInterval(timer); 13 timer = null; // 釋放定時器變量 14 }); 15 con.addEventListener('mouseleave', function() { 16 arrow_l.style.display = 'none'; // 將左右箭頭display設爲none 17 arrow_r.style.display = 'none'; 18 // 鼠標離開再從新開啓定時器 19 timer = setInterval(function() { 20 // 手動調用點擊事件 21 arrow_r.click(); // 自動輪播 22 }, 2000); 23 }); 24 25 var ul = con.querySelector('ul'); 26 var ol = con.querySelector('ol'); 27 // 動態添加底部小圓圈 28 for(var i = 0; i < ul.children.length; i++) { 29 var li = document.createElement('li'); 30 // 經過添加自定義屬性來記錄小圓圈索引號 31 li.setAttribute('index', i); 32 ol.appendChild(li); 33 // 生成小圓圈的同時就能夠給它綁定單擊事件 34 li.addEventListener('click', function() { 35 // 排他思想 幹掉全部人,留下我本身 36 for(var i = 0; i < ol.children.length; i++) { // 先把全部的小圓圈改成未選中狀態 37 ol.children[i].className = ''; 38 } 39 // 再把當前小圓圈改成選中狀態 40 this.className = 'current'; 41 var index = this.getAttribute('index'); // 獲取當前小圓圈的索引 42 // 將index值賦值給num以及circle,將小圓圈的點擊事件和左右箭頭點擊事件同步 43 num = index; 44 circle = index; 45 animate(ul, - index * conWidth); 46 }) 47 } 48 // 讓第一個小圓圈底色爲白色(選中狀態) 49 ol.children[0].className = 'current'; 50 // 克隆第一張圖片 51 var first = ul.children[0].cloneNode(true); // true 深拷貝 52 ul.appendChild(first); // 拷貝第一張圖片添加到ul最後 53 54 var num = 0; // 用來存儲點擊後圖片序號 55 var circle = 0; // 用來存儲點擊後小圓圈序號 56 var flag = true; // flag 節流閥 防止用戶點擊過快 圖片播放太快 57 // 右側箭頭點擊播放 58 arrow_r.addEventListener('click', function() { 59 if(flag) { 60 // 點擊後先關閉節流閥 61 flag = false; 62 // 若是播放到了最後一張,就把left直接值設爲0從頭播放,同時還原num 63 if(num == ul.children.length - 1) { 64 ul.style.left = 0; 65 num = 0; 66 } 67 num++; 68 animate(ul, - num * conWidth, function() { 69 // 回調函數 動畫執行完後開啓節流閥 70 flag = true; 71 }); 72 // 小圓圈和箭頭一塊兒變化 73 circle++; 74 /* if(circle == ol.children.length) { 75 circle = 0; 76 } */ 77 // 能夠用三元運算符判斷小圓圈是否到了最後一個,若是是最後一個就還原circle 78 circle == ol.children.length ? circle = 0 : circle; 79 circleChange(); // 使當前小圓圈爲選中狀態 80 } 81 }) 82 83 // 左側箭頭點擊播放 84 arrow_l.addEventListener('click', function() { 85 if(flag) { 86 // 關閉節流閥 87 flag = false; 88 // 若是播放到了第一張,就把left值設爲最後一張的值 89 if(num == 0) { 90 num = ul.children.length - 1; 91 ul.style.left = - num * conWidth + 'px'; 92 } 93 num--; 94 animate(ul, - num * conWidth, function() { 95 flag = true; 96 }); 97 // 小圓圈和箭頭一塊兒變化 98 circle--; 99 // circle < 0 時說明是第一張圖片,將小圓圈改成第四個(索引爲3) 100 if(circle < 0) { 101 circle = ol.children.length - 1; 102 } 103 circleChange(); 104 } 105 }) 106 // 小圓圈的選中狀態(相同代碼能夠封裝爲一個函數,使代碼更簡潔) 107 function circleChange() { 108 // 排他思想 109 for(var i = 0; i < ol.children.length; i++) { 110 ol.children[i].className = ''; 111 } 112 ol.children[circle].className = 'current'; 113 } 114 // 自動播放輪播圖,至關於隔一段時間調用一次右側箭頭點擊事件 115 var timer = setInterval(function() { 116 // 手動調用點擊事件 117 arrow_r.click(); 118 }, 2000); 119 })