当前位置 : 主页 > 网络编程 > JavaScript >

原生js轮播插件.html

来源:互联网 收集:自由互联 发布时间:2021-06-28
原生js轮播插件(优势,体积小) 原生js轮播插件 附加photoSlider.js源码(修改过) /* * * photoSlider.v1.21 * create by Gavin * 2015-3-26 * http://www.j--d.com/photoSlider/ * Edit By Damon * 2015-06-28 * http://perfey.g
原生js轮播插件(优势,体积小)


	原生js轮播插件
	



 
    
   
   
附加photoSlider.js源码(修改过)
/*
 * 
 * photoSlider.v1.21
 * create by Gavin
 * 2015-3-26
 * http://www.j--d.com/photoSlider/
 * Edit By Damon
 * 2015-06-28
 * http://perfey.github.io/photoSlider/index.html
 * */
function photoSlider(options) {
	this.wrap = options.wrap;
	this.wrapWidth = this.wrap.offsetWidth;
	this.wrapInner = this.wrap.getElementsByTagName('ul')[0];
	this.lists = this.wrap.getElementsByTagName('li');
	this.listLength = this.lists.length;
	var defaults = {
		loop: false, //无缝循环
		autoPlay: false, //自动轮播
		autoTime: 5000, //自动轮播时间间隔
		speed: 300, //动画过渡时间
		pagination: true //状态点
	}
	this.ops = options || {};
	for (var i in defaults) {
		if (typeof options[i] === 'undefined') {
			options[i] = defaults[i];
		} else if (typeof options[i] === 'object') {
			for (var deepDef in defaults[i]) {
				if (typeof options[i][j] === 'undefined') {
					options[i][j] = defaults[i][j];
				}
			}
		}
	};
	this.init();
	this.bindEvent();
}
photoSlider.prototype.createSprite = function () {
	var divSprite = document.createElement('div');
	divSprite.className = 'spinner';
	for (var i = 0; i < 3; i++) {
		var div = document.createElement('div');
		div.className = 'bounce' + parseInt(i + 1);
		divSprite.appendChild(div);
	}
	this.wrap.appendChild(divSprite);
	var imgObj = new Image();
	imgObj.src = this.lists[this.listLength - 1].getElementsByTagName('img')[0].src;
	var _this = this;
	imgObj.onload = function () {
		divSprite.remove();
		_this.wrapInner.style.opacity = '1';
	}
}
photoSlider.prototype.init = function () {
	this.ratio = this.wrap.offsetHeight / this.wrap.offsetWidth;
	this.wrapWidth = this.wrap.offsetWidth;
	// this.wrapHeight = this.wrap.offsetHeight;
	// this.wrapInner.style.width = this.wrapWidth + 'px';
	this.index = 0;
	//初始化lists值
	for (var i = 0; i < this.listLength; i++) {
		this.lists[i].style.left = i * this.wrapWidth + 'px';
		/*var listImg = this.lists[i].getElementsByTagName('img')[0];
		if (listImg.height / listImg.width > this.ratio) {
			listImg.style.height = this.wrapHeight + 'px';
		} else {
			listImg.style.width = this.wrapWidth + 'px';
		}
		delete listImg;*/
	};
	if (this.ops.pagination) {
		this.createBullet();
	};
	if (this.ops.loop) {
		this.copyLists();
		this.index = 2;
		this.listLength = this.wrapInner.getElementsByTagName('li').length;
	};
	//自动轮播
	if (this.ops.autoPlay) {
		this.autoPlay();
	};
	//窗口大小初始化方法
	var _this = this,
		resizeTimer = null;
	window.onresize = function () {
		if (resizeTimer) clearTimeout(resizeTimer);
		resizeTimer = setTimeout(function () {
			_this.resizeInit();
		}, 300);
	};
};
photoSlider.prototype.resizeInit = function () {
	// this.ratio = this.wrap.offsetHeight / this.wrap.offsetWidth;
	this.wrapWidth = this.wrap.offsetWidth;
	// this.wrapHeight = this.wrap.offsetHeight;
	// this.wrapInner.style.width = this.wrapWidth + 'px';
	for (var i = 0; i < this.listLength; i++) {
		var j = i - 2;
		this.lists[i].style.left = this.wrapWidth * j + 'px';
	};
	this.move('0');
}
//copy首尾lists
photoSlider.prototype.copyLists = function () {
	var lastLi = document.createElement('li'),
		lastSecLi = document.createElement('li'),
		firstLi = document.createElement('li'),
		secondLi = document.createElement('li');
	lastLi.style.left = '-' + this.wrapWidth + 'px';
	lastLi.innerHTML = this.lists[this.listLength - 1].innerHTML;
	lastSecLi.style.left = '-' + this.wrapWidth * 2 + 'px';
	lastSecLi.innerHTML = this.lists[this.listLength - 2].innerHTML;
	firstLi.style.left = this.wrapWidth * this.listLength + 'px';
	firstLi.innerHTML = this.lists[0].innerHTML;
	secondLi.style.left = this.wrapWidth * (this.listLength + 1) + 'px';
	secondLi.innerHTML = this.lists[1].innerHTML;
	this.wrapInner.insertBefore(lastLi, this.wrapInner.firstChild);
	this.wrapInner.insertBefore(lastSecLi, this.wrapInner.firstChild);
	this.wrapInner.appendChild(firstLi);
	this.wrapInner.appendChild(secondLi);
}
//创建状态点列表
photoSlider.prototype.createBullet = function () {
	var pagination = document.createElement('div');
	pagination.className = 'pagination';
	for (var i = 0; i < this.listLength; i++) {
		var span = document.createElement('span');
		if (this.index == i) {
			span.className = 'active';
		}
		pagination.appendChild(span);
	}
	this.wrap.appendChild(pagination);
	this.bulletLists = pagination.getElementsByTagName('span');
	this.bllength = this.bulletLists.length;
}
photoSlider.prototype.autoPlay = function () {
	var _this = this;
	clearInterval(_this.timer);
	_this.timer = setInterval(function () {
		_this.move('+1');
	}, _this.ops.autoTime);
}
photoSlider.prototype.stopPlay = function () {
	clearInterval(this.timer);
}
photoSlider.prototype.Transform3d = function (elm, x, m) {
	if (!elm) {
		throw new Error('未指定动画元素!');
	} else {
		elm.style.transform = 'translate3d(' + x + 'px,0,0)';
		elm.style.webkitTransform = 'translate3d(' + x + 'px,0,0)';
	};
	if (m) {
		elm.style.transition = 'all ' + this.ops.speed + 'ms ease-out 0s';
		elm.style.webkitTransition = 'all ' + this.ops.speed + 'ms ease-out 0s';
	} else {
		elm.style.transition = 'none';
		elm.style.webkitTransition = 'none';
	}
}
photoSlider.prototype.loopSetting = function (n) {
	var _this = this;
	switch (n) {
		case 1:
			setTimeout(function () {
				mindex = _this.listLength - 3;
				_this.index = mindex;
				_this.Transform3d(_this.wrapInner, -_this.wrapWidth * (_this.listLength - 5), false);
			}, _this.ops.speed);
			break;
		case _this.listLength - 2:
			setTimeout(function () {
				mindex = 2;
				_this.index = mindex;
				_this.Transform3d(_this.wrapInner, 0, false);
			}, _this.ops.speed);
			break;
	}
}
photoSlider.prototype.move = function (m) {
	var mindex, _this = this;
	if (typeof m == 'number') {
		mindex = this.index;
	} else if (typeof m == 'string') {
		mindex = this.index + m * 1;
	}
	//循环播放暂时不需要
	if (mindex > this.listLength - 1) {
		mindex = this.listLength - 1;
	} else if (mindex < 0) {
		mindex = 0;
	}
	//状态点列表切换方法
	this.index = mindex;
	var i = -1 * (this.index);
	this.Transform3d(this.wrapInner, i * this.wrapWidth, true);

	//状态点列表切换方法
	if (this.ops.pagination) {
		var activeNum = 0;
		if (mindex == 1) {
			activeNum = 1;
		} else if (mindex == (this.listLength)) {
			activeNum = 0;
		} else {
			activeNum = mindex;
		}
		setTimeout(function () {
			for (var i = 0; i < _this.bllength; i++) {
				if (i == activeNum) {
					_this.bulletLists[i].setAttribute('class', 'active');
				} else {
					_this.bulletLists[i].setAttribute('class', '');
				}
			}
		}, 100);
	}
	//无缝循环设置
	if (this.ops.loop) {
		this.loopSetting(this.index);
	}
}
photoSlider.prototype.bindEvent = function () {
	var _this = this;
	var moveWidth = this.wrapWidth / 3;
	var touchstart = function (e) {
		_this.startX = e.touches[0].pageX;
		_this.startY = e.touches[0].pageY;
		//初始化移动的距离
		_this.offsetX = 0;
		_this.startTime = new Date() * 1;
		_this.stopPlay();
	};
	var touchmove = function (e) {
		_this.offsetX = e.touches[0].pageX - _this.startX;
		_this.offsetY = e.touches[0].pageY - _this.startY;
		if (Math.abs(_this.offsetX) > Math.abs(_this.offsetY)) {
			e.preventDefault();
			//源码为:var i = -1 * (_this.index - 2);
			var i = -1 * (_this.index);//bug修改
			_this.Transform3d(_this.wrapInner, i * _this.wrapWidth + _this.offsetX, false);
		}
	};
	var touchend = function (e) {
		var endTime = new Date() * 1;
		if (endTime - _this.startTime > 700) {
			if (_this.offsetX >= moveWidth) {
				_this.move('-1');
			} else if (_this.offsetX < -moveWidth) {
				_this.move('+1');
			} else {
				_this.move('0');
			}
		} else {
			if (_this.offsetX >= 60 || (_this.offsetX > 0 && _this.offsetX > 0.25 * (endTime - _this.startTime))) {
				_this.move('-1');
			} else if (_this.offsetX < -60 || (_this.offsetX < 0 && _this.offsetX < 0.25 * (endTime - _this.startTime))) {
				_this.move('+1');
			} else {
				_this.move('0');
			}
		}
		if (_this.ops.autoPlay) {
			_this.autoPlay();
		}
	};
	_this.wrap.addEventListener('touchstart', touchstart, false);
	_this.wrap.addEventListener('touchmove', touchmove, false);
	_this.wrap.addEventListener('touchend', touchend, false);
};

function photoSlide(options) {
	return new photoSlider(options);
};
网友评论