jQuery:如何在尚未添加到 DOM 的元素上调用 jQuery 插件函数?

时间:2023-01-27
本文介绍了jQuery:如何在尚未添加到 DOM 的元素上调用 jQuery 插件函数?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我有一个我正在使用的 jQuery 插件:

I have a jQuery plugin that I am using:

$(document).ready(function(){
    $('.elements').fancyPlugin();
});

在我开始添加新元素之前效果很好:

This works great until I start adding new elements:

$.get('ajax.html', function(data){
    $('#container').html(data);
});

我可以像这样再次调用插件函数:

I could call the plugin function again like this:

$.get('ajax.html', function(data){
    $('#container').html(data).find('.elements').fancyPlugin();
});

...除了 AJAX 发生在另一个不需要知道 fancyPlugin() 的 jQuery 插件中.

...except that the AJAX is happening inside another jQuery plugin that shouldn't have to know about the fancyPlugin().

如何将此插件应用于所有当前和未来的元素?

How can I apply this plugin to all current and future elements?

推荐答案

我认为这将适用于除 IE 之外的所有浏览器:

I think this will work in all browsers except IE:

document.body.addEventListener("DOMNodeInserted", function(event){
    var $elementJustAdded = $(event.target);
    if ($elementJustAdded.hasClass('elements')) {
        $elementJustAdded.fancyPlugin();
    }
}, false);

这篇关于jQuery:如何在尚未添加到 DOM 的元素上调用 jQuery 插件函数?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

上一篇:允许数字、空格、加号、连字符和括号的正则表达式 下一篇:使用 jQuery 验证插件:onfocusout、onkeyup 在生产站点上未按预期工作

相关文章

最新文章