当离开页面asp.net时,当文本框上有输入时,提示用户保存

时间:2013-11-17 12:33:32

标签: javascript asp.net save

我使用jquery和javascript找到了几个解决方案,但是,它必须声明jquery中的所有字段,但它效率不高,因为我的表单上有30多个asp文本框,如何提示用户保存已在页面卸载时进行数据或更改。

2 个答案:

答案 0 :(得分:1)

假设所有文本文本框都具有相同的样式类(下面使用'inputField'),您可以使用以下内容:

$( window ).unload(function() {
  if ($('.inputField').is(':empty')){
    alert('Please fill all text boxes');
  }
});

答案 1 :(得分:1)

我用这个:

请务必在字段上设置default =“”属性!

function formIsDirty(form) {
    var i, j, element, type;
    if(typeof form === 'undefined') {
        return false;
    }

    for (i = 0; i < form.elements.length; i += 1) {
        element = form.elements[i];
        type = element.type;
        if (type === "checkbox" || type === "radio") {
            if (element.checked !== element.defaultChecked) {
                return true;
            }
        } else if (type === "hidden" || type === "password" || type === "text" || type === "textarea") {
            if (element.value !== element.defaultValue) {
                return true;
            }
        } else if (type === "select-one" || type === "select-multiple") {
            for (j = 0; j < element.options.length; j += 1) {
                if (element.options[j].selected !== element.options[j].defaultSelected) {
                    return true;
                }
            }
        }
    }
    return false;
}


$( window ).unload(function() {
    if(formIsDirty(document.forms["formName"])) {
        return confirm("There are unsaved changes, leave this page?");
    }
}

作为额外提示,当您在asp中生成页面时,如果将default =“”属性设置为数据库中的当前值,则不仅可以检测它是否为空,而且是否已更改该值。

这也允许正确使用form.reset()按钮/方法(w3Schools page here