首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >特定于DOM元素的函数覆盖或函数

特定于DOM元素的函数覆盖或函数
EN

Stack Overflow用户
提问于 2011-01-05 22:20:23
回答 2查看 501关注 0票数 1

假设我想做一个叫做'alertMeOnRemove‘的小插件,这是不言而喻的。我希望它只覆盖调用它的元素的remove()函数。

代码语言:javascript
复制
$('a').alertMeOnRemove();
$('div').remove(); // no alert
$('a.subset-of-a').remove(); //alert
$('a').remove() //alert

我知道一般的重写jQuery函数既可能也很容易。这个是可能的吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-01-05 22:39:45

是啊,那并不难。

代码语言:javascript
复制
(function(){
    var _remove = $.fn.remove;

    $.fn.alertMeOnRemove = function(){
        this.each(function(){
            $.data(this, 'alertMeOnRemove', true);
        });
    };

    $.fn.remove = function(){
        this.each(function(){
            if ($.data(this, 'alertMeOnRemove')) {
                alert('removing item');
            }
        });

        _remove.call(this);
    };
})();
票数 2
EN

Stack Overflow用户

发布于 2011-01-05 22:36:08

我不确定我是否能理解你,但你可以这样做:

代码语言:javascript
复制
var _oldRemove = $.fn.remove;
$.fn.remove = function() {
    if(/* some condition */)
       alert('foobar');

    _oldRemove.apply(this, arguments);
};
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4605064

复制
相关文章

相似问题

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