gpt4 book ai didi

javascript - jQuery 更改事件不会在动态创建的元素上触发

转载 作者:行者123 更新时间:2023-12-03 10:11:41 25 4
gpt4 key购买 nike

我目前正在尝试使用 list.js 和 lodash 对一组搜索结果生成动态过滤功能。代码的基础是从这里 fork 的:

http://codepen.io/waynehoover/pen/KBqhF

List.Js 使用页面上的元素创建一个数据集,然后可以对其进行过滤或排序。但是,由于这些是搜索结果,我希望使过滤器动态化,以便仅显示页面上存在的条件。

上面的示例使用了多选列表,但在我的示例中,我已将它们转换为复选框。我现在遇到的主要问题是,我正在动态创建复选框,它们不再在更改时触发 updateList() 方法。

我尝试过简单地使用 JQuery 中的 .change() 方法以及 .on("change",updateList()) 但这些似乎都不起作用。有什么想法吗?

下面的代码和 Codepen。

HTML

<div id="users">
<input class="search" placeholder="Search" />

<div>
Filter Name:
<label><input type="checkbox" name="names" value="Jonny Wayne">Johnny Wayne</label>
<label><input type="checkbox" name="names" value="Jonas">Jonas</label>
<label><input type="checkbox" name="names" value="Martina">Martina</label>
<label><input type="checkbox" name="names" value="Gustaf">Gustaf</label>
</div>

<div class="namesContainer"></div>
<div class="dateContainer"></div>

<ul class="list">
<li>
<h3 class="name">Jonny Wayne</h3>
<p class="born">1986</p>
</li>
<li>
<h3 class="name">Jonas</h3>
<p class="born">1985</p>
</li>
<li>
<h3 class="name">Jonas</h3>
<p class="born">1985</p>
</li>
<li>
<h3 class="name">Jonas</h3>
<p class="born">1985</p>
</li>
<li>
<h3 class="name">Martina</h3>
<p class="born">1986</p>
</li>
<li>
<h3 class="name">Gustaf</h3>
<p class="born">1983</p>
</li>
</ul>

</div>

<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.0.3/jquery.min.js"></script>
<script src="//cdnjs.cloudflare.com/ajax/libs/lodash.js/2.4.1/lodash.min.js"></script>
<script src="http://cdnjs.cloudflare.com/ajax/libs/list.js/1.1.0/list.min.js"></script>

Javascript

var options = { valueNames: [ 'name', 'born' ] };
var userList = new List('users', options);

var updateList = function(){
var names = new Array();
var dates = new Array();

$("input:checkbox[name=names]:checked").each(function() {
names.push($(this).val());
});

$("input:checkbox[name=dates]:checked").each(function() {
dates.push($(this).val());
});

var values_date = dates.length > 0 ? dates : null;
var values_name = names.length > 0 ? names : null;

userList.filter(function(item) {
return (_(values_date).contains(item.values().born) || !values_date)
&& (_(values_name).contains(item.values().name) || !values_name)
});
}

$(function(){
updateList();
$("input:checkbox[name=dates]").change(updateList);
$("input:checkbox[name=names]").change(updateList);

var all_born = [];
var all_name = [];

_(userList.items).each(function(item){
all_born.push(item.values().born)
all_name.push(item.values().name)
});

_(all_born).uniq().each(function(item){
$(".dateContainer").append('<label><input type="checkbox" name="dates" value="'+item+'">'+ item +'</label>')
});


});

Codepen

http://codepen.io/JasonEspin/pen/waKjxW

提前致谢。

最佳答案

像这样使用:

 $(document).off("change","input:checkbox[name=dates]");
$(document).on("change","input:checkbox[name=dates]",updateList);
$(document).off("change","input:checkbox[name=names]");
$(document).on("change","input:checkbox[name=names]",updateList);

关于javascript - jQuery 更改事件不会在动态创建的元素上触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30081875/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com