http://taskcn.blog. 163.com/
基于jQuery的淡入淡出可自动切换的幻灯插件打包下载基于jQuery淡入淡出可自动切换的幻灯插件,原型是前几天写的一个幻灯效果,因为一个小bug卡了两天,然后清空之前写的代码,重新整理思路写出来的.
思维是个很诡异的东西,一旦陷入某个死角,很难逃出.惟有冷却一些时间,完全抛开旧的思维,才能找到新的出路.
其实就是一个幻灯效果,考虑到使用方便,就封装成一个插件了.
插件特点
1.参数高度自定义;
2.可重复调用且与不影响;
3.插件文件小,压缩后仅1.04k,开发版3.29k.
演示及下载
使用方法
1. 引入jQuery库文件及jQuery. iFadeSlide.pack. js插件文件(若页面有其他js文件,可与之合并以减小http请求) ,引入位置自定义;
复制代码代码如下:scriptsrc="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min. js"/scriptscript 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调用---传入新的参数,将覆盖原有参数,未传入的使用默认值http://taskcn.blog. 163.com/
http://taskcn.blog. 163.com/
$('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 = " uliset.field.each(function(i) {ulcon = ulcon + ' li ' + (i + 1) + ' /li
} ) ;ulcon += ' /uliset. 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) ;http://taskcn.blog. 163.com/
http://taskcn.blog. 163.com/
} ) ;
//为当前索引添加高亮样式并移除同级元素中的高亮样式
$(obj) .addClass(iset.hoverCls) . siblings() .removeClass(iset.hoverCls) ;} ;
//切换函数var changeFun = function() {index++; //累积索引值if (index == size) {index = 0} ; //当索引值等于切换元素量时,初始化为0ico.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) ;http://taskcn.blog. 163.com/
提速啦的来历提速啦是 网站 本着“良心 便宜 稳定”的初衷 为小白用户避免被坑 由赣州王成璟网络科技有限公司旗下赣州提速啦网络科技有限公司运营 投资1000万人民币 在美国Cera 香港CTG 香港Cera 国内 杭州 宿迁 浙江 赣州 南昌 大连 辽宁 扬州 等地区建立数据中心 正规持有IDC ISP CDN 云牌照 公司。公司购买产品支持3天内退款 超过3天步退款政策。提速啦的市场定位提速啦主...
轻云互联怎么样?轻云互联,广州轻云网络科技有限公司旗下品牌,2018年5月成立以来,轻云互联以性价比的价格一直为提供个人,中大小型企业/团队云上解决方案。本次轻云互联送上的是美国圣何塞cn2 vps(免费50G集群防御)及香港沙田cn2 vps(免费10G集群防御)促销活动,促销产品均为cn2直连中国大陆线路、采用kvm虚拟技术架构及静态内存。目前,轻云互联推出美国硅谷、圣何塞CN2GIA云服务器...
PhotonVPS 服务商我们是不是已经很久没有见过?曾经也是相当的火爆的,我们中文习惯称作为饭桶VPS主机商。翻看之前的文章,在2015年之前也有较多商家的活动分享的,这几年由于服务商太多,乃至于有一些老牌的服务商都逐渐淡忘。这不有看到PhotonVPS商家发布促销活动。PhotonVPS 商家七月份推出首月半价Linux系统VPS主机,首月低至2.5美元,有洛杉矶、达拉斯、阿什本机房,除提供普...