以“图片渐入渐出”为例讲述jQuery插件的具体实现

摘要:
首先,这段代码最初是由网友“Smeor”创建的,作为对这个例子的解释;在我们这样做之前,让我们先看看我们想要做出的效果:分析以下样式:我们希望图片在“特定时间”后自动切换。右下角有小正方形的数字1,2,3,4。这些数字会根据图片的数量自动显示。当鼠标标记经过时,数字颜色会发生一定程度的变化;让我们看看如何实现它。相对生成相对定位元素,以相对于其正常位置定位它们。

首先声明,此代码以网友“斯迈欧”原创作为此例的讲解;

在这之前我们先看看我们要做的效果是什么样的:

解析下面的样式:我们要图片在过“一定时间”后自动切换,在右下角处有小方块似数字1,2,3,4,这些数字是根据图片的个数自动出现的,当鼠标经过的时候数字颜色有一定的变化

下面我们来看看具体怎么实现。

以“图片渐入渐出”为例讲述jQuery插件的具体实现第1张

第一步:先写简单的html页面

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <script type="text/javascript" src="../js/jquery.js" ></script>
    <script type="text/javascript" src="scrollPic.js" ></script>
    <link rel="stylesheet" href="scrollPic.css">
</head>
<body>
    <div class="pic-slider-io">
        <ul>
            <li><img src="images/1.jpg" /></li>
            <li><img src="images/2.jpg" /></li>
            <li><img src="images/3.jpg" /></li>
            <li><img src="images/4.jpg" /></li>
        </ul>
    </div>    
</body>
</html>

页面代码解析:首先建立scrollPic.html,scrollPic.js,scrollPic.css。二话不说先把要的三个基本的文件建好;然后把它引入到html中在head头部,其中注意

 src="http://t.zoukankan.com/js/jquery.js"
这个代码的意思,“../”表示跳出上级目录,然后在js文件夹下查找jquery.js文件;
在html页面中,我们在body中添加一个class为'pic-slider-io'的div,在div中有一个ul,li下面有四张图片,注意:图片事先设置好命名,为1.jpg,2.jpg......方便在编写scrollPic.js;
先看看这个时候什么都没做的页面样式:

以“图片渐入渐出”为例讲述jQuery插件的具体实现第2张

可以看到图片是一原来的大小平铺在页面上的,一默认ul li的方式展现在页面上的;
现在我们要把它放在左下角;

第二步:
编写css样式来控制他
首先控制div的展现:
.pic-slider-io{
    height : 200px;   //设置div的高为200px;
    width : 800px;  //设置div的宽为800px;
    float  : letf;   //float 属性定义元素在哪个方向浮动。以往这个属性总应用于图像,使文本围绕在图像周围,不过在 CSS 中,任何元素都可以浮动。浮动元素会生成一个块级框,而不论它本身是何种元素。
    position : relative;  //position 属性规定元素的定位类型.这个属性定义建立元素布局所用的定位机制。任何元素都可以定位,不过绝对或固定元素会生成一个块级框,而不论该元素本身是什么类型。相对定                //位元素会相对于它在正常流中的默认位置偏移。relative 生成相对定位的元素,相对于其正常位置进行定位。
    overflow : hidden; //overflow 属性规定当内容溢出元素框时发生的事情.hidden 内容会被修剪,并且其余内容是不可见的。
}

看一下页面样式:

以“图片渐入渐出”为例讲述jQuery插件的具体实现第3张


看到所有图片都在一起去了,图片的本身大于div的宽高,所以overflow:hidden这个就把其他溢出的就不显示了,不过这肯定不是我们想要的,不急继续;
然后,我们现在控制ul的样式:
.pic-slider-io ul{
    margin : 0px; //设置上下左右的外边距都为0;
    padding : 0px;//设置上下左右的内边距都为0;   注意:margin,padding的设置是:上,右,下,左;如margin : 2px,4px,5px,8px;分别对应的是上,右,下,左;
    height : auto;  //自适应高度,浏览器自动计算
    width : 100%;  //宽度为100%
    list-style-type : none;      //把li的点去掉
    float  : left;  
    display : block;  //此元素将显示为块级元素,此元素前后会带有换行符
    position : absolute;//生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。
    top : 0;
    left : 0;
    z-index : 98;//z-index 属性设置元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。
}

这个时候图片就不显示了,页面看到的是把左上角那个去掉了;

再次,我们控制li的样式:

.pic-slider-io ul li {
    height: auto;
    width: 100%;
    float: left;
    padding: 0px;
    margin: 0px; 
    overflow: hidden;
    z-index:1; //这个li层就比ul那个叠层更高
}

这个样式的设置主要是把li的叠层高于ul 就相当于浮在ul上面;

最后,我们来看看img的样式:

.pic-slider-io ul li img{ 
    width: 100%;
     z-index:1;//设置图片和li在同一层上,这个应该没问题吧
}

现在我们来看看页面成什么样了:

以“图片渐入渐出”为例讲述jQuery插件的具体实现第4张

看到,经过样式设置,整个图片都显示出来了;

第三步:编写scrollPic.js
在编写js的时候,我们要添加右下方的图片数字显示,我们事先把要添加的css写好如下:

.pic-page-btn {//这是在父div中的子div样式,用于显示在右下角的数字承载模块
    float: left;
    width: auto;
    height: 30px; 
    position: absolute; 
    bottom: 20px; 
    right: 20px;
    z-index: 99;  //他的叠层比父级div还要高,把这个按钮样式放在图片之上
}
.pic-page-btn span{ //这个是设置子div的数字样式
    height: 30px;
    width: 30px;
    background-color: #999;
    display: block;
    float: left;
    line-height: 30px;
    text-align: center;
    color: #FFF;
    margin-right: 10px;
    cursor:pointer;
}
.pic-page-btn .current {//这是将要设置鼠标滑过改变其背景颜色
    background-color: #1D5D76;
}

下面,我们来看看js的编写,在这里不是视频,就不一步一步的讲了,我把各个解释都注释在js代码中了

js代码:

$(function(){
    $.scrollPic = function (options){ //定义了一个scrollPic函数,有一个传参,用于调用;
         /************************开始整个默认插件参数讲解*******************************/
       //整个defaults以花括号包含的是默认的参数,调用此插件的只需要修改ele,Time,autoscroll即可;
        var defaults={
            ele: '.pic-slider-io',     //pic-slider-io是一个class,css中定义了其样式;
            Time : '2000',            //Time是定义了滑动的时间;
            autoscroll : true        //autoscroll设为true表示自动切换图片;
        };
        /************************结束整个默认插件参数讲解*******************************/
        
        //$.extend({},defaults, option)有{}主要是为了创建一个新对象,保留对象的默认值。
        var opts = $.extend({}, defaults, options);
        
        //$(opts.ele)可以理解为取这个执行,与$('.class1').click();类似表示,然后理解为赋值给PicObject;
        //或者这样理解,$(opts.ele)就是$('.pic-slider-io'),只不过(.pic-slider-io是个class作为参数,所以要(opts.ele)来表示);
        var PicObject = $(opts.ele);
        
        //PicObject.find('ul'),这个可以理解成$(opts.ele).find('ul'),因为opts.ele其实就是取得的一个class,
        //相当于$('.pic-slider-io').find('ul');然后赋值给scrollList,所以整个就用scrollList来表示他;
        var scrollList = PicObject.find('ul');
        
        //同理scrollList.find('li')可以表示为$('.pic-slider-io').find('ul').find('li');所以这个是一层一层来查找的如果你看到html就会更加清晰;
        var listLi = scrollList.find('li');
        
        //图片的命名是1.jpg,2.jpg,这样的,index是用来表示图片的名字的初始化赋值为0;
        var index = 0;
        
        //这是定义一个picTimer(自动切换函数)的函数;
        var picTimer;
        
        //一个li中包含一个图片,所以这是查找有多少个图片,赋值给len;
        var len = PicObject.find('li').length;
        
        /*****************开始自动切换函数************************/
        function picTimer(){
            showPic(index);//调用showPic(index)函数(在下面)
            index++;
            if(index == len){//如果index的值等于len,就表示从第一张图片到最后一张图片切换完了,然后是index赋值为0重新开始
                index=0;
            }
        }
        /*****************结束自动切换函数************************/
        
        
        //setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式。
        //setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭
        //此判断为如果autoscroll为true,则不停的调用picTimer函数,以Time的速度调用
        if(opts.autoscroll){
            var time = setInterval(picTimer,opts.Time);
        }
        
        
        /*****************开始动画函数************************/
        function showPic(index){//定义动画函数
            //listLi是找到第一个li,然后隐藏他,listLi在var listLi = scrollList.find('li');已经介绍了
            listLi.hide();
            //fadeIn() 方法使用淡入效果来显示被选元素,假如该元素是隐藏的。siblings()方法是遍历。
            listLi.eq(index).fadeIn(500).siblings().hide();
            //找到paging对应的css样式,如果与当前的index一致,则添加class为current的css样式,否则就移除。
            PicObject.find(paging).eq(index).addClass('current').siblings().removeClass('current');
        }
        /*****************结束动画函数************************/
        
        //这是在class为pic-slider-io的div中添加一个class为pic-page-btn的子div。
        //主要是设置右下角数字的承载
        PicObject.append('<div class="pic-page-btn"></div>');
        
        //在这个class为pic-page-btn的子div中添加图片张数对应的数字个数,1,2,3,,,,,
        //从这可以看出来,数字不是自己一个个添得,是根据li的个数,也就是图片的个数自动生成的
        for( i=1;i<=len;i++){
            PicObject.find('.pic-page-btn').append('<span>'+i+'</span>');
        }
        
        //这个就是和上面讲listLi一样的
        var paging = PicObject.find('.pic-page-btn span');
        
        //为相应的右下角的数字改变其背景颜色
        paging.eq(index).addClass('current');
        
    }
});

在这我们差不多完成了图片的切换,

然后我们在html中先调用默认的看一看:

调用方式:

<script type="text/javascript">
$(function(){
        $.scrollPic();
   }); 
</script>

看一下界面显示:

以“图片渐入渐出”为例讲述jQuery插件的具体实现第5张

看箭头所示,说明可以自动切换了图片;
可是我们还有当鼠标在右下角1,2,3,4上滑过的时候,可以切换图片,所以我们就在js中加个事件就可以了:

        //鼠标经过1、2、3、4的效果
        PicObject.find(paging).mouseover(function(){
            index = PicObject.find(paging).index($(this));
            showPic(index); //调用showPic(index)函数。
        });
        //鼠标经过1、2、3、4的效果
        
        //清除计时器
        //当鼠标悬浮在1,2,3,4上面的时候,就相当于要切换图片了
        //所以我们就要清除计时器,重新来过了
        PicObject.hover(function(){
            clearInterval(time);//这个是相对于setInterva()的;
        },function(){
            if(opts.autoscroll){
                time = setInterval(picTimer,opts.Time);
            }else{
                clearInterval(time);
            }
        });

把这段代码加如到js中,加到什么位置就不要说了吧!加到

 paging.eq(index).addClass('current');
后面就可以了;



这样整个这个图片切换的一个插件就算完成了;
如果需要调用函数,可以修改ele,Timer,autoscroll.
看一下带参数使用插件:
<script type="text/javascript">
 $(function(){
        $.scrollPic({
            ele: '.pic-slider-io',   //插件应用div
            Time:'3000',          //自动切换时间
            autoscroll:true,       //设置是否自动渐变
      });
   }); 
</script>

好了,整个插件的讲述就算是完成了,希望大家可以从中学到知识,如有不足,还望谅解!(最后说一句,在整个js的编写时,最好在$(function(){});的最前面加个分号,防止与其他js冲突)



免责声明:文章转载自《以“图片渐入渐出”为例讲述jQuery插件的具体实现》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇[转]小程序实现原理解析服务应用之WEB与WCF使用之见下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

React和Jquery比较

Jquery的工作方式: 假如你需要给一个按扭添加一个点击事件。 首先根据CSS规则找到对应的dom元素,挂上一个匿名事件处理函数,在事件处理函数中,选中那个需要被修改的DOM元素,读取他的文本值,加以修改,然后修改这个dom元素。 优点:直观易懂。缺点:对于庞大的项目,会造成代码结构复杂,难以维护。 React的工作理念:   打一个比方, Rea...

c++与js脚本交互,C++调用JS函数/JS调用C++函数

<!DOCTYPE html> <html> <body> <h1>我的第一段 JavaScript</h1> <p> JavaScript 能够对事件作出反应。比如对按钮的点击: </p> <button type="button" onc...

QT基础三

4.1The Central Widget QMainWindow的中央区域可以被任何类型的widget占据。 4.2Subclassing QTableWidget QTableWidget会自动创建QTableWidgetItem来存储用户的输入。 QTableWidgetItem类并不是widget,而是一个纯粹的data class。 QTabeW...

Boost库学习(3) 内存管理

preface: 1、传统C++内存管理中可能出现的问题:内存泄露、野指针、访问越界;相关解决方案:智能指针 std::auto_ptr,不能完全解决内存管理中出现的问题; 2、关于smart_ptr库的概述: 2.1、C++程序员通常采用RAII(资源获取即初始化)机制管理内存资源,在使用资源的类的构造函数中申请资源,最后在析构函数中释放资源;如果对象的...

jquery模拟点击事件

在某些情况下,我们需要自动执行一些点击事件。比如:一些 tab 一般是通过点击事件来加载不同的数据内容。 而如果要页面加载完直接显示第三个 tab,怎么办呢?此时就需要用到 jQuery 的模拟点击事件。 要用到 jQuery 的 trigger 方法。 如: $('#btn').trigger("click"); 会自动执行 id 为 btn 的 cli...

python魔法方法、构造函数、序列与映射、迭代器、生成器

在Python中,所有以__双下划线包起来的方法,都统称为"魔术方法"。比如我们接触最多的__init__,魔法方法也就是具有特殊功能的方法。 构造函数 构造函数不同于普通方法,将在对象创建后自动调用它们。也就是在对象创建完成后,自动会调用__init__方法来初始化。 创建一个构造方法 构造方法传参 >>> classFooBar...