jQuery源码分析17: .toggle()

jQuery源码分析17: .toggle()

jQuery.extend({
    // A global GUID counter for objects
    guid: 1,
});

jQuery.fn.extend({
    toggle: function( fn ) {
        // Save reference to arguments for access in closure
        var args = arguments,
            guid = fn.guid || jQuery.guid++,
            i = 0,
            toggler = function( event ) {
                // Figure out which function to execute
                var lastToggle = ( jQuery._data( this, "lastToggle" + fn.guid ) || 0 ) % i;
                jQuery._data( this, "lastToggle" + fn.guid, lastToggle + 1 );

                // Make sure that clicks stop
                event.preventDefault();

                // and execute the function
                return args[ lastToggle ].apply( this, arguments ) || false;
            };

        // link all the functions, so any of them can unbind this click handler
        toggler.guid = guid;
        while ( i < args.length ) {
            args[ i++ ].guid = guid;
        }

        return this.click( toggler );
    },
});

// Save the old toggle function
_toggle: jQuery.fn.toggle,

toggle: function( fn, fn2, callback ) {
    var bool = typeof fn === "boolean";
 
    if ( jQuery.isFunction(fn) && jQuery.isFunction(fn2) ) {
        this._toggle.apply( this, arguments );
    } else if ( fn == null || bool ) {   //< 当调用$(elem).toggle([true|false|\s*]);时相当于.show(),.hide()
        this.each(function() {
            var state = bool ? fn : jQuery(this).is(":hidden");
            jQuery(this)[ state ? "show" : "hide" ]();   //< <==> jQuery(this)['show'](),jQuery(this)['hide']()
        });
    } else {
        this.animate(genFx("toggle", 3), fn, fn2, callback);
    }
 
    return this;
},
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值