demo.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
<link rel="stylesheet" href="css/banner.css">
</head>
<body>
<div class="qf-banner">
<ul class="banner-inner">
<li>
<img src="images/1.jpg" alt="">
</li>
<li>
<img src="images/2.jpg" alt="">
</li>
<li>
<img src="images/3.jpg" alt="">
</li>
<li>
<img src="images/4.jpg" alt="">
</li>
<li>
<img src="images/5.jpg" alt="">
</li>
<li>
<img src="images/6.jpg" alt="">
</li>
</ul>
<ul class="banner-tip"></ul>
<a href="javascript:;" class="left-btn"></a>
<a href="javascript:;" class="right-btn"></a>
</div>
<script src="js/common.js"></script>
<script src="js/move1.1.0.js"></script>
<script src="js/swiper2.0.js"></script>
<script>
swiper.init('.qf-banner');
</script>
</body>
</html>
move1.1.0.js
// 若是多個參數須要選填, 把多個參數當成一個對象, 這樣就沒有前後順序問題了
function move(ele, attr, target, options) {
// 把options裏面傳入的參數, 替換__default
const __default = {
time: 500,
callback: null,
...options
}
let $box = ele;
if(typeof ele == 'string') {
$box = $(ele);
}
clearInterval($box.timer);
let init = parseFloat(getStyle($box, attr));
if(attr == 'opacity') {
init *= 100;
}
// (目標值 - 初始值) / 次 = (時間 / 頻率)
let speed = (target - init) / (__default.time / 10);
$box.timer = setInterval(function () {
init += speed;
if ((speed <= 0 && init <= target) || (speed >= 0 && init >= target)) {
// 終止運動條件
init = target;
clearInterval($box.timer);
if (typeof __default.callback == 'function')
__default.callback($box);
}
if(attr == 'opacity') {
$box.style[attr] = init / 100
} else {
$box.style[attr] = init + 'px';
}
}, 10)
}
swiper2.0.js
// var swiper = (function() {
// let $showBox,
// $imgBox,
// $imgLiBox,
// $tipsBox,
// $preBtn,
// $nextBtn,
// $tipsAll = [],
// showBoxWidth,
// showIndex, // 當前展現圖片的索引
// timer; // 定時器
// return {
// init(ele) {
// // 獲取所用dom元素
// $showBox = $(ele);
// showBoxWidth = $showBox.clientWidth;
// $imgBox = $showBox.querySelector('.banner-inner');
// $imgLiBox = $imgBox.children;
// $tipsBox = $showBox.querySelector('.banner-tip');
// // 獲取上一個按鈕
// $preBtn = $showBox.querySelector('.left-btn');
// // 獲取下一個按鈕
// $nextBtn = $showBox.querySelector('.right-btn');
// // $tipsAll = $tipsBox.children;
// // 根據圖片的位數, 建立對應的小圓圈
// this.createTips($imgLiBox.length);
// // 獲取第一張圖片的li
// const $firstLi = $imgLiBox[0];
// console.log($firstLi);
// // console.log($imgBox.firstElementChild);
// // 獲取最後一張圖片的li
// const $lastLi = $imgLiBox[$imgLiBox.length - 1];
// // console.log($imgLiBox);
// // 把第一張克隆到最後一張
// $imgBox.appendChild($firstLi.cloneNode(true));
// // 把最後一張克隆到第一張
// $imgBox.insertBefore($lastLi.cloneNode(true), $firstLi);
// // 克隆之後, 應該仍是展示第一張
// $imgBox.style.left = -showBoxWidth + 'px';
// this.showImage(0);
// this.autoPlay();
// this.event();
// },
// event() {
// var _this = this;
// $tipsBox.onclick = function(e) {
// e = e || window.event;
// const target = e.target || e.srcElement;
// if(target.nodeName == 'LI') {
// _this.showImage(target.index);
// _this.autoPlay()
// }
// }
// $preBtn.onclick = function() {
// _this.showImage(showIndex - 1);
// _this.autoPlay();
// }
// $nextBtn.onclick = function() {
// _this.showImage(showIndex + 1);
// _this.autoPlay()
// }
// },
// createTips(num) {
// for(let i = 0; i< num; i++) {
// const $li = document.createElement('li');
// $li.index = i;
// $tipsBox.appendChild($li);
// // 把全部的tip存放到數組中
// $tipsAll.push($li);
// }
// },
// showImage(index) {
// // 合法判斷
// let maxIndex = $tipsAll.length - 1
// if(index < 0) {
// // 展現最後一張圖片
// index = maxIndex;
// $imgBox.style.left = -showBoxWidth * ( maxIndex + 2) + 'px';
// } else if(index > maxIndex) {
// // 展現第一張
// index = 0;
// $imgBox.style.left = 0 + 'px';
// }
// showIndex = index;
// $tipsAll.forEach(x => {
// x.classList.remove('active');
// })
// $tipsAll[index].classList.add('active');
// move($imgBox, 'left', -showBoxWidth * (index + 1));
// },
// autoPlay() {
// clearInterval(timer);
// timer = setInterval( _ => {
// this.showImage(showIndex + 1);
// }, 2000)
// }
// }
// }())
var swiper = (function(){
let $showBox,
$imgBox,
$imgLiBox,
$tipsBox,
$preBtn,
$nextBtn,
$tipsAll = [],
$showBoxWidth,
showIndex,
timer;
return{
init(ele){
$showBox = $(ele);
//由於經過 DOM 已經獲取了$showBox,因而能夠從$showBox中找到.banner-inner
showBoxWidth = $showBox.clientWidth;
$imgBox = $showBox.querySelector('.banner-inner');
$imgLiBox = $imgBox.children;
$tipsBox = $('.banner-tip');
// $tipsAll = $tipsBox.children;
$preBtn = $('.left-btn');
$nextBtn = $('.right-btn');
// console.log($imgLiBox.length);
this.createTips($imgLiBox.length);
const $firstLi = $imgLiBox[0];
const $lastLi = $imgLiBox[$imgLiBox.length - 1];
$imgBox.appendChild($firstLi.cloneNode(true));
$imgBox.insertBefore($lastLi.cloneNode(true),$firstLi);
$imgBox.style.left = -showBoxWidth + 'px';
this.showImage(0);
this.event();
this.autoPlay();
},
event(){
var _this = this;
$tipsBox.onclick = function(e){
e = e || window.event;
const target = e.target || e.srcElent;
if(target.nodeName == 'LI'){
_this.showImage(target.index) ;
}
}
$preBtn.onclick = function(){
_this.showImage(showIndex - 1);
_this.autoPlay();
}
$nextBtn.onclick = function(){
_this.showImage(showIndex + 1);
_this.autoPlay();
}
},
createTips(num){
for(let i= 0;i < num;i ++){
const $li = document.createElement('li');
$li.index = i;
$tipsBox.appendChild($li);
$tipsAll.push($li);
}
},
showImage(index){
let maxIndex = $tipsAll.length - 1;
if(index < 0){
index = $tipsAll.length - 1;
$imgBox.style.left = -showBoxWidth*($tipsAll.length + 2) +'px';
}else if(index > maxIndex){
index = 0;
$imgBox.style.left = 0 + 'px';
}
showIndex = index;
$tipsAll.forEach((x, i) => {
x.classList.remove('active');
})
$tipsAll[index].classList.add('active');
move($imgBox,'left',-showBoxWidth * (index + 1));
},
autoPlay(){
clearInterval(timer);
timer = setInterval( _ =>{
this.showImage(showIndex + 1)
},2000);
}
}
}())
common.js
// 判斷數組是否還有這個元素
function include(arr, item) {
for(var i = 0; i < arr.length; i++) {
if(arr[i] === item) {
return true;
}
}
return false;
}
// 返回元素所在的位置
function indexOf(arr, item) {
for(var i = 0; i < arr.length; i++) {
if(arr[i] === item) {
return i;
}
}
return -1;
}
// 任意區間隨機整數
function getRandom(max, min) {
min = min || 0;
if(min > max) {
var a = min;
min = max;
max = a;
}
return min + Math.floor(Math.random() * (max - min + 1));
}
// 數組去重
function noRepeat(arr) {
var __arr = [];
for(var i = 0; i < arr.length; i++) {
// 存在返回true, 不存在返回false
var bool = __arr.indexOf(arr[i])
if(bool == -1) {
__arr.push(arr[i]);
}
}
return __arr;
}
function $(ele) {
return document.querySelector(ele);
}
function $A(ele) {
return document.querySelectorAll(ele);
}
function getRandomColor() {
var str = '0123456789abcdef';
var color = '#';
for(var i = 0; i < 6; i++) {
color += str[getRandom(str.length - 1)];
}
return color;
}
// 格式化url, 獲取參數
function parseUrl(url) {
var obj = {};
url = url.split('?')[1].split('#')[0];
url = url.split('&');
url.forEach(function (x) {
var arr = x.split('=');
obj[arr[0]] = arr[1];
})
return obj;
}
// 獲取非行內樣式
function getStyle(ele, attr) {
if(window.getComputedStyle) {
return window.getComputedStyle(ele, null)[attr]
}
return ele.currentStyle[attr];
}