jquery - 将 .on() 与 .not() 链接起来以从对象中删除不需要的元素

标签 jquery jquery-selectors onbeforeunload

我有一个网络表单,我将 beforeunload 事件绑定(bind)到窗口,以检测表单的任何更改除了我不需要包含的输入。例如,我不需要绑定(bind) beforeunload 事件的输入。它应该只绑定(bind)那些会影响离开窗口时丢失更改的输入。

这是我当前的绑定(bind):

formChanged = false;
$('#main-form').on('change.form_change', 'input:not(.leave-change-allowed), textarea:not(.leave-change-allowed), select:not(.leave-change-allowed)', function()
{
    if(!formChanged)
    {
        formChanged = true;

        $(window).bind('beforeunload', function()
        {
            if(formChanged)
            {
                return 'Are you sure you want to navigate away from this window, you will lose unsaved changes.';
            }
        });
    }
    else
    {
        $(this).unbind('change.form_change');   
    }
});

如您所见,我已将 :not(.leave-change-allowed) 添加到选择器中的元素中,并用逗号分隔以选择表单元素。虽然,我不想将 not() 添加到选择器中,因为我想添加到 not() 中的选择器可能很少,但我会需要应用于每个表单输入inputtextareaselect。请记住,这些元素是动态的,因此我使用了 .on() 而不是 .change()

如何将 .not() 函数与动态元素链接起来?所以我保持选择器不变,并在 .not() 函数中传递所有不必要的元素?

最佳答案

检查函数内类的目标:

formChanged = false;
$('#main-form').on('change.form_change', 'input, textarea, select', function(e) {
    if(! (formChanged || $(e.target).is('.leave-change-allowed')) ) {
        formChanged = true;
        $(window).on('beforeunload', function() {
            if(formChanged) {
                return 'Are you sure you want to navigate away from this window, you will lose unsaved changes.';
            }
        });
    } else {
        $(this).off('change.form_change');   
    }
});

关于jquery - 将 .on() 与 .not() 链接起来以从对象中删除不需要的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15535863/

相关文章:

javascript - 使用 ajax 更新 JSP 页面中的对象

javascript - javascript 中的事件顺序无法正常运行

Javascript 如何 : hide the browser popup for onBeforeUnload and display custom popup

javascript - 如何仅在 html 表格中未设置背景时更改背景颜色

javascript - jQuery 获取具有特定类的父级

javascript - 可能的 JQuery 类选择器错误

jQuery 遍历 DOM - 单击按钮时按类定位项目

javascript - 内容幻灯片

javascript - Firefox 中的 onbeforeunload

javascript - onload、onunload、onbeforeunload 之间的区别