jQuery焦点图切换简易插件制作过程全纪录(2)
五、创建插件各个操作
/**
* @method private
* @name _getSlides
* @description 获取幻灯片对象
* @param $node [jQuery object] "目标对象"
*/
function _getSlides($node) {
return $node.children('li');
}
/**
* @method private
* @name _build
* @description Builds each instance
* @param $node [jQuery object] "目标对象"
* @param opts [object] "插件参数"
*/
function _build($node, opts) {
var $slides = _getSlides($node);
$slides.eq(0).siblings('li').css({'display':'none'});
var numpic = $slides.size() - 1;
$node.delegate('li', 'mouseenter', function() {
pause = true;//暂停轮播
clearInterval(autoMethod);
}).delegate('li', 'mouseleave', function() {
pause = false;
autoMethod = setInterval(function() {
_auto($slides, $pages, opts);
}, opts.speed);
});
//console.log(autoMethod)
var $pages = _pagination($node, opts, numpic);
if(opts.auto) {
autoMethod = setInterval(function() {
_auto($slides, $pages, opts);
}, opts.speed);
}
}
1、_getSlides用于获取ul这个对象的li子标签,ul也就是这个焦点图插件
2、将除了第一个li标签,其他标签设置为隐藏
3、获取切换图片的数量,由于后面做循环是从下标0开始,做<=操作,所以减去一个1,其实这里不减也是可以的,看个人喜好
4、给li标签设置mouseenter与mouseleave的事件,分别是取消循环与继续循环
5、初始化选择按钮
6、参数auto如果为true,就激活自动切换
六、初始化选择按钮
/**
* @method private
* @name _pagination
* @description 初始化选择按钮
* @param $node [jQuery object] "目标对象"
* @param opts [Object] "参数"
* @param size [int] "图片数量"
*/
function _pagination($node, opts, size) {
var $ul = $('<ul>', {'class': opts.pageCss});
for(var i = 0; i <= size; i++){
$ul.append('<li>' + '<a href="javascript:void(0)">' + (i+1) + '</a>' + '</li>');
}
$ul.children(':first').addClass('current');//给第一个按钮选中样式
var $pages = $ul.children('li');
$ul.delegate('li', 'click', function() {//绑定click事件
var changenow = $(this).index();
_changePage($pages, $node, changenow);
}).delegate('li', 'mouseenter', function() {
pause = true;//暂停轮播
}).delegate('li', 'mouseleave', function() {
pause = false;
});
$node.after($ul);
return $pages;
}
1、动态添加按钮ul标签,赋上一个自定义class,将子标签li加上
2、将第一个按钮加上选中样式
3、给li标签加上click、mouseenter与mouseleave的事件,click事件绑定切换操作
4、把分页按钮放到插件对象ul的后面
5、返回分页按钮中的li对象,后面有用的
七、切换图片
/**
* @method private
* @name _change
* @description 幻灯片显示与影藏
* @param $slides [jQuery object] "图片对象"
* @param $pages [jQuery object] "按钮对象"
* @param next [int] "要显示的下一个序号"
*/
function _fadeinout($slides, $pages, next){
$slides.eq(nowImage).css('z-index','2');
$slides.eq(next).css({'z-index':'1'}).show();
$pages.eq(next).addClass('current').siblings().removeClass('current');
$slides.eq(nowImage).fadeOut(400, function(){
$slides.eq(next).fadeIn(500);
});
}
1、将当前的图片z-index加大,下一张图片的z-index也加大,显示下一张图,这样能做出一种渐变的效果,不加的话就会是很生硬的切换
2、选择按钮的下一个增加选中样式
3、应用jQuery的fadeOut与fadeIn做隐藏与显示的渐变特效
八、自动循环
/**
* @method private
* @name _auto
* @description 自动轮播
* @param $slides [jQuery object] "图片对象"
* @param $pages [jQuery object] "按钮对象"
* @param opts [Object] "参数"
*/
function _auto($slides, $pages, opts){
var next = nowImage + 1;
var size = $slides.size() - 1;
if(!pause) {
if(nowImage >= size){
next = 0;
}
_fadeinout($slides, $pages, next);
if(nowImage < size){
nowImage += 1;
}else {
nowImage = 0;
}
}else {
clearInterval(autoMethod);//暂停的时候就取消自动切换
}
}
1、判断是暂停还是继续轮播
2、如果不是暂停,就根据条件做当前页与下一个按钮的序号设置
插件还有很多问题,比如不能在一个页面绑定两个不同的对象,还有巨大的修改空间。






