我的页面上有一个Foundation 5下拉菜单,工作正常。但是,当我在下拉区域中提交表单时,会在页面顶部添加一个新元素,以便所有元素都向下移动。之后,我所有的下拉菜单都停止工作。(如果我跳过将元素添加到 DOM,一切正常)
我的下拉菜单:
<div id="file-tab">
<i data-dropdown="shareForm16" aria-controls="shareForm16" aria-expanded="false" class="iconTrigger"></i>
<form data-dropdown-content class="share-form f-dropdown content" aria-hidden="true" tabindex="-1" action="" id="shareForm16">
...
</form>
</div>
我以为我需要重新绑定基础事件侦听器,但它不起作用。也许我只是做错了。
$('#file-tab').on("submit", 'form.share-form',function(e){
e.preventDefault();
var groupName = $(form.target).find('input[type="text"]').val();
var id = $(e.target).parent().children('input[type="hidden"]').val();
if (groupName) {
$(e.target).trigger('click');
window.currentFTT.share(id ,groupName); // adds the element to the DOM
// my attempt to rebind:
$('#'+e.target.id).foundation({bindings: 'events'});
$('i[aria-controls="'+e.target.id+'"]').foundation({bindings: 'events'});
}
});
不是为单个元素调用foundation
,而是对foundation
进行常规调用,将"reflow"作为参数传递:
$(document).foundation('reflow');
例如:
$('#file-tab').on("submit", 'form.share-form',function(e){
e.preventDefault();
var groupName = $(form.target).find('input[type="text"]').val();
var id = $(e.target).parent().children('input[type="hidden"]').val();
if (groupName) {
$(e.target).trigger('click');
window.currentFTT.share(id ,groupName); // adds the element to the DOM
// my attempt to rebind:
$(document).foundation('reflow');
}
});