jQuery: How to call a jQuery plugin function on an element that hasn#39;t yet been added to the DOM?(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:如何在尚未添加到 DOM 的元素上调用 jQuery
- 为什么悬停在委托事件处理程序中不起作用? 2022-01-01
- 如何调试 CSS/Javascript 悬停问题 2022-01-01
- 如何显示带有换行符的文本标签? 2022-01-01
- 我不能使用 json 使用 react 向我的 web api 发出 Post 请求 2022-01-01
- 是否可以将标志传递给 Gulp 以使其以不同的方式 2022-01-01
- 如何向 ipc 渲染器发送添加回调 2022-01-01
- 为什么我的页面无法在 Github 上加载? 2022-01-01
- 从原点悬停时触发 translateY() 2022-01-01
- 使用 iframe URL 的 jQuery UI 对话框 2022-01-01
- 在不使用循环的情况下查找数字数组中的一项 2022-01-01