基于jQuery的淡入淡出可自动切换的幻灯插件打包下载


Posted in Javascript onSeptember 15, 2010

思维是个很诡异的东西,一旦陷入某个死角,很难逃出. 惟有冷却一些时间,完全抛开旧的思维,才能找到新的出路.
其实就是一个幻灯效果,考虑到使用方便,就封装成一个插件了.

插件特点

1. 参数高度自定义;
2. 可重复调用且与不影响;
3. 插件文件小,压缩后仅1.04k,开发版3.29k.

演示及下载

点此查看DEMO
点此下载插件

使用方法
1. 引入jQuery库文件及jQuery.iFadeSlide.pack.js插件文件(若页面有其他js文件,可与之合并以减小http请求),引入位置自定义;

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script> 
<script src="js/jquery.iFadeSldie.pack.js"></script>

样式文件无须引入,若使用DEMO中的结构,可直接将样式合并于项目页面中.建议样式自定义.
2. 在页面中调用插件并传入切换元素的参数, 若为空或未传入的参数,均按插件中的默认参数执行.例如如下代码是DEMO演示中的三组幻灯切换调用:
$(function(){ 
//SAMPLE-A调用---未传入任何参数,调用默认参数 
$('div#slide').iFadeSlide(); 
//SAMPLE-B调用---传入新的参数,将覆盖原有参数,未传入的使用默认值 
$('div#slide_b').iFadeSlide({ 
field: $('div#slide_b a'), 
icocon:$('div.ico_b'), 
hoverCls: 'high_b', 
curIndex: 2, //索引值0起始,故此处设置为第3项高亮 
interval: 2000 
}); 
//SAMPLE-C调用---传入新的参数,将覆盖原有参数,未传入的使用默认值 
$('div#slide_c').iFadeSlide({ 
field: $('div#slide_c img'), 
icocon: $('div.ico_c'), 
outTime:100, 
inTime: 200 
}); 
});

注意,调用插件部分须置入插件文件引用后面.
核心代码
;(function($){ 
$.fn.extend({ 
iFadeSlide: function(options){ 
//插件参数初始化 
var iset={ 
field:$('div#slide img'), //切换元素集合 
icocon:$('div.ico'), //索引容器 
hoverCls:'high', //切换至当前索引高亮显示样式 
curIndex:0, //默认高亮显示的索引值,索引值为0起始 
outTime:200, //元素淡出时间(ms) 
inTime:300, //元素淡入时间(ms) 
interval:3000 //元素切换间隔时间(ms) 
}; 
options=options || {}; 
$.extend(iset,options); //合并参数对象.若options传入有新值则覆盖iset中对应值,否则使用默认值. 
//根据切换元素量生成对应的索引值列表并插入到切换区域中 
var ulcon = "<ul>"; 
iset.field.each(function(i){ 
ulcon = ulcon + '<li>' + (i + 1) + '</li>'; 
}); 
ulcon += '</ul>'; 
iset.icocon.append(ulcon); 
var ico = iset.icocon.find('li'); //索引列表集合 
var size = iset.field.size(); //切换元素量 
var index = 0; //初始索引值 
var clearFun=null; 
//淡出淡入函数 
var fadeFun = function(obj){ 
index = ico.index(obj); //取当前索引值 
//淡出当前可见元素,并通过索引值找到要淡入的元素 
iset.field.filter(':visible').fadeOut(iset.outTime, function(){ 
iset.field.eq(index).fadeIn(iset.inTime); 
}); 
//为当前索引添加高亮样式并移除同级元素中的高亮样式 
$(obj).addClass(iset.hoverCls).siblings().removeClass(iset.hoverCls); 
}; 
//切换函数 
var changeFun = function(){ 
index++; //累积索引值 
if (index == size){index = 0}; //当索引值等于切换元素量时,初始化为0 
ico.eq(index).trigger('mouseleave'); //为当前的索引模拟鼠标划出元素区事件 
}; 
//自动切换函数 
var scrollFun = function(){ 
clearFun = setInterval(function(){ 
changeFun() 
}, iset.interval); 
}; 
//停止自动切换函数 
var stopFun = function(){ 
clearInterval(clearFun); 
}; 
scrollFun(); //初始自动切换 
//索引区域鼠标划入停止自动切换并切换元素至当前索引,鼠标划出初始化索引至当前值(否则鼠标划出切换会乱) 
ico.hover(function(){ 
stopFun(); 
fadeFun(this); 
}, function(){ 
fadeFun(this); 
}).eq(iset.curIndex).mouseleave(); //初始高亮显示的索引值 
//切换区域鼠标划入停止自动切换,划出继续自动 
iset.field.hover(function(){ 
stopFun(); 
}, function(){ 
scrollFun(); 
}); 
} 
}); 
})(jQuery);
Javascript 相关文章推荐
jQuery 选择器项目实例分析及实现代码
Dec 28 Javascript
Jquery ajax执行顺序 返回自定义错误信息(实例讲解)
Nov 06 Javascript
js怎么判断flash swf文件是否加载完毕
Aug 14 Javascript
教你如何使用node.js制作代理服务器
Nov 26 Javascript
jquery实现对联广告的方法
Feb 05 Javascript
javascript数组去重的六种方法汇总
Aug 16 Javascript
Eclipse引入jquery报错如何解决
Dec 01 Javascript
AngularJs验证重复密码的方法(两种)
Nov 25 Javascript
Vue2学习笔记之请求数据交互vue-resource
Feb 23 Javascript
浅谈angular4 ng-content 中隐藏的内容
Aug 18 Javascript
微信小程序实现下拉刷新动画
Jun 21 Javascript
js通过canvas生成图片缩略图
Oct 02 Javascript
基于JQuery的简单实现折叠菜单代码
Sep 15 #Javascript
jQuery获取css z-index在各种浏览器中的返回值
Sep 15 #Javascript
JavaScript具有类似Lambda表达式编程能力的代码(改进版)
Sep 14 #Javascript
手把手教你自己写一个js表单验证框架的方法
Sep 14 #Javascript
(jQuery,mootools,dojo)使用适合自己的编程别名命名
Sep 14 #Javascript
修改jquery里的dialog对话框插件为框架页(iframe) 的方法
Sep 14 #Javascript
基于jquery的划词搜索实现(备忘)
Sep 14 #Javascript
You might like
某大型网络公司应聘时的笔试题目附答案
2008/03/27 PHP
php strtotime 函数UNIX时间戳
2009/01/14 PHP
php 魔术方法使用说明
2009/10/20 PHP
PHP COOKIE及时生效的方法介绍
2014/02/14 PHP
orm获取关联表里的属性值
2016/04/17 PHP
PHP输出多个元素的排列或组合的方法
2017/03/14 PHP
javascript实现二分查找法实现代码
2007/11/12 Javascript
JS禁用浏览器退格键实现思路及代码
2013/10/29 Javascript
js全选实现和判断是否有复选框选中的方法
2015/02/17 Javascript
JavaScript判断是否为数字的4种方法及效率比较
2015/04/01 Javascript
常用DOM整理
2015/06/16 Javascript
js倒计时简单实现代码
2016/08/11 Javascript
JS 中使用Promise 实现红绿灯实例代码(demo)
2017/10/20 Javascript
原生javascript实现连连看游戏
2019/01/03 Javascript
微信小程序之 catalog 切换实现解析
2019/09/12 Javascript
jQuery实现轮播图效果demo
2020/01/11 jQuery
python爬虫系列Selenium定向爬取虎扑篮球图片详解
2017/11/15 Python
Python 实现淘宝秒杀的示例代码
2018/01/02 Python
Python原始套接字编程实例解析
2020/01/29 Python
详解使用Python写一个向数据库填充数据的小工具(推荐)
2020/09/11 Python
Python用摘要算法生成token及检验token的示例代码
2020/12/01 Python
HTML5如何使用SVG的方法示例
2019/01/11 HTML / CSS
Lookfantastic挪威官网:英国知名美妆购物网站
2017/07/26 全球购物
阿玛瑞酒店中文官方网站:Amari.com
2018/02/13 全球购物
丝芙兰波兰:Sephora.pl
2018/03/25 全球购物
Genny意大利官网:意大利高级时装品牌
2020/04/15 全球购物
农田水利实习自我鉴定
2013/09/19 职场文书
酒店管理专业学生求职信
2013/09/27 职场文书
工作违纪检讨书
2014/02/17 职场文书
《会走路的树》教后反思
2014/04/19 职场文书
勤俭节约演讲稿
2014/05/08 职场文书
大学学雷锋活动总结
2014/06/26 职场文书
土建施工员岗位职责
2015/04/11 职场文书
2015年绩效考核工作总结
2015/05/23 职场文书
毕业生登记表班级意见
2015/06/05 职场文书
Win11 PC上的Outlook搜索错误怎么办?
2022/07/15 数码科技