首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >jQuery函数中的“`return this`”,具有正确(保留)的链接性

jQuery函数中的“`return this`”,具有正确(保留)的链接性
EN

Stack Overflow用户
提问于 2012-12-02 07:15:03
回答 2查看 70关注 0票数 0

我需要一个等待函数,从下面开始:

代码语言:javascript
复制
var delay = (function() {
    return function(callback, ms) {
        setTimeout(callback, ms || 1000);
    };
})();

delay(function() {
    $('#foo').animate({
        height: 180
    }, 1000);
});

然后移植到jQuery:

代码语言:javascript
复制
jQuery.fn.wait = function(callback, seconds) {
    return this.each(function() {
        return setTimeout(callback, seconds || 1000);
    });
};

$('#second').wait(function() {
    $('#second').addClass('foo'); // works well
});​

最终在混乱中结束:

代码语言:javascript
复制
$('#second').wait(function() {
    $(this).addClass('foo'); // `this` will not work here
});​

...我最后一个实例化的问题在哪里,或者更好的是我该如何修复它?this在这里查看window-object,而不是实际的#second-element...

除此之外,如果超时为0,是否有可能让“链”走得更远?因此,如果我们有以下场景,则仅当计时器结束时才会添加类:

代码语言:javascript
复制
$('#second').wait().addClass('foo');
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-12-02 07:25:26

this没有为您提供所需元素的原因是因为您试图在没有设置上下文的函数中使用它,请尝试

代码语言:javascript
复制
jQuery.fn.wait = function(callback, seconds) {
    return this.each(function() {
        var self = this
        return setTimeout(function(){
                   callback.call(self);
               }, seconds || 1000);
    });
};
票数 0
EN

Stack Overflow用户

发布于 2012-12-02 07:17:04

这与链式无关。

链接意味着在方法的返回值上调用额外的jQuery方法。($(...).wait(...).somethingElse())。

您的方法已经支持链接,因为它返回this (通过this.each(),它本身是可链接的)。

您正在询问如何使用特定的this值调用回调:

代码语言:javascript
复制
var self = this;
callback.call(self);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13664733

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档