zoukankan      html  css  js  c++  java
  • 写第一个jquery插件实录

    插件的功能很简单,就只是点击一个图片,图片在弹出框出现,后面有个背景层。由于CSS,HTML的各种基础都一般,学js刚14天,所以写这个还是花了点时间。

    首先是结构,img文件夹里放需要的图片。index.html除了引用需要的js文件以及css文件之外,还需要写入图片的html代码。

    <a href="img/caicai.jpg" title="Ashida1" class="thumbnail"><img src="img/caicai.jpg"/></a>

    main.js里写调用插件的代码:

    $(document).ready(function(){
        $(".thumbnail").otBox({
        });
    });

    这里所有thumbnail类都能调用otBox方法,于是要定义otBox方法,而且要把otBox方法定义在jQuery的原型中,这样所有的jQuery实例都能使用。所以otBox.js里面有$.fn.otBox = function(options){}的方法,详细如下:

        $.fn.otBox = function(options){
            var $this = this;
            var options = $.extend({},$.fn.otBox.defaults,options);
    
            $this.each(function(){
    
                Object.create(otBox).init($(this),options);
            });
        };
     

    这里的$this指的是调用这个插件的由选择器选择出来的对象数组,比如在main里使用$(".thumbnail")选择了所有这个类的<a>元素,对于每一个<a>,都能进行插件的功能。于是在$.fn.otBox函数里,对数组里的每一个对象都进行了插件功能的初始化。初始化的时候需要将调用otBox的jQuery实例传入,即每一个<a>元素,也就是each里面的this,用$()封装成jQuery。由于在$(".thumbnail").otBox({});中,所有选择出来的元素享用同一组options参数(有默认参数,用户也可以自己传参),因此在each前就可以对options进行统一合并。使用jQuery中的extend方法,将$.fn.otBox.defaults(默认)和options(用户传入)一起合并到{}里面,传给var options。

    Object.create(object)方法生成一个object的实例方法,它的内部like this:

            Object.create = function (pro){
                function F(){};
                F.prototype = pro;
                return new F();
            }

    init是otBox的初始化函数。现在我们来看看otBox对象的定义:

        var otBox = {
            init:function(instance,options){
                this.instance=instance;//instance指的是调用otBox的jQuery实例,而this是otBox实例
                this.options=options;
                var $this=this;
    
    //            生成bg和showbox的html部分
                var $showBox= $("<div class='show_box'><img src='' alt=''/></div><div class='bg_lock'></div>");
                $('body').append($showBox);
    
    
                this.instance.on('click',function(e){
                    e.preventDefault();
    //                console.log(this); 
                    $this.showBg();
                    $this.showBox(this['href']);
                });
    
                $('.bg_lock').click(function(){
                    $this.hideBox();
                    $this.hideBg();
                });
    
            },
            showBg: function(){
                $('.bg_lock').show();
            },
            showBox: function(url){
                $('.show_box>img').attr('src',url);
                $('.show_box').show();
            },
            hideBg:function(){
                $('.bg_lock').hide();
            },
            hideBox:function(){
                $('.show_box>img').attr('src','');
                $('.show_box').hide();
            }
        };

    主要是init部分,这里之所以要传入之前调用otBox的jQuery实例,是因为在init里面会绑定对实例的click方法,于是需要知道是哪个<a>被click了,弹出对应的图片。而在init里面的this指的是otBox实例。先在init里面在把弹出层和背景层的html动态添加到页面中,因为总不能让用户手动来填这部分html代码吧。然后,定义click事件,绑定在调用otBox的那个jQuery实例上,也就是传进来的instance。首先防止默认行为,也就是对a的跳转,然后分别show背景和弹出层,在弹出层的时候,把所需图片的url传入。在这个事件绑定函数中,由于this变成了click绑定的dom对象,也就是<a>元素,于是直接使用this['href']就可以取出图片的url。而showBg()等函数都需要otBox实例才能调用,所以用的是$this。

    其余函数只是为了实现弹出层和背景层的出现和消失。

    附上otBox的css文件,里面有关于弹出层和背景图的基本css实现:

    a.thumbnail img{
        width:200px;
    
    }
    
    .bg_lock{
        display: none;
        height:100%;
        width: 100%;
        position:absolute;
        top:0%;
        left:0%;
        background-color: black;
        z-index:1000;
        opacity: 0.5;
    }
    
    .show_box{
        position: absolute;
        top: 10%;
        left: 25%;
        width:50%;
        z-index: 1001;
    
    
    }
    
    .show_box>img{
        width:100%;
        border-radius: 12px;
    }
    otBox.css

    哇!最后展示下我的小菜菜!

    附上otBox.js文件

    /**
     * Created by OT on 14-1-6.
     */
    (function ($){
    
        if( typeof Object.create !== 'function'){
            Object.create = function (pro){
                function F(){};
                F.prototype = pro;
                return new F();
            }
        };
    
        var otBox = {
            init:function(instance,options){
                this.instance=instance;//instance指的是调用otBox的jQuery实例,而this是otBox实例
                this.options=options;
                var $this=this;
    
    //            生成bg和showbox的html部分
                var $showBox= $("<div class='show_box'><img src='' alt=''/></div><div class='bg_lock'></div>");
                $('body').append($showBox);
    
                this.instance.on('click',function(e){
                    e.preventDefault();
                    $this.showBg();
                    $this.showBox(this['href']);
                });
    
                $('.bg_lock').click(function(){
                    $this.hideBox();
                    $this.hideBg();
                });
    
            },
            showBg: function(){
                $('.bg_lock').show();
            },
            showBox: function(url){
                $('.show_box>img').attr('src',url);
                $('.show_box').show();
            },
            hideBg:function(){
                $('.bg_lock').hide();
            },
            hideBox:function(){
                $('.show_box>img').attr('src','');
                $('.show_box').hide();
            }
        };
    
        $.fn.otBox = function(options){
            var $this = this;
            var options = $.extend({},$.fn.otBox.defaults,options);
    
            $this.each(function(){
    
                Object.create(otBox).init($(this),options);
            });
        };
    
        $.fn.otBox.defaults = {};
    
    })(jQuery);
    otBox.js

    这里首先是自执行函数,为了避免污染全局,所以用函数封装,为了让里面的代码执行一遍,于是把函数设成自执行,之所以要传jQuery进去,是怕有其他地方也有定义$,所以为了确保在otBox文件中使用的$就是jQuery,传了这个参数进去。函数里面第一部分是由于可能低版本的jQuery还不支持Object.create(),所以手动定义一下。

  • 相关阅读:
    spring FactoryBean配置Bean
    注意使用 BTREE 复合索引各字段的 ASC/DESC 以优化 order by 查询效率
    Mysql经常使用基本命令汇总及默认账户权限与改动
    图像边缘检測--OpenCV之cvCanny函数
    HDU 1556 Color the ball 树状数组 题解
    JMeter使用记录2 -- Web測试
    C++编程
    矩阵树定理速证
    DM816x算法具体解释--之OSD
    哥尼斯堡的“七桥问题”(25分)(欧拉回路,并查集)
  • 原文地址:https://www.cnblogs.com/yuanting0505/p/3512098.html
Copyright © 2011-2022 走看看