设置表单的默认值、检测表单是否变更

原创 2015年11月19日 14:32:15

通过动态加载表单内容,要求检测加载之后有没有变更过,可以通过defaultValue或者defaultSelected、defaultChecked属性来完成


首先,加载完成后设置默认值为当前状态的值:

//设置当前值为表单默认值
function setDefault(element) {
    if (typeof (element) == "string") {
        element = document.getElementById(element);
        if (!element) { return null; }
    }
    var type = element.type;
    if (type == "checkbox" || type == "radio") {
        element.defaultChecked = element.checked;
    }
    else if (type == "hidden" || type == "password" || type == "text" || type == "textarea") {
        element.defaultValue = element.value;
    }
    else if (type == "select-one" || type == "select-multiple") {
        for (var j = 0; j < element.options.length; j++) {
            element.options[j].defaultSelected = element.options[j].selected;
        }
    }
    var childs = element.childNodes;
    for (var i = 0; i < childs.length; i++) {
        setDefault(childs[i]);
    }
}


检测代码:

//判断表单是否改变过
function formIsDirty(form) {
    if (typeof (form) == "string") {
        form = document.getElementById(form);
        if (!form) { return null;}
    }
    for (var i = 0; i < form.elements.length; i++) {
        var element = form.elements[i];
        var 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 (var j = 0; j < element.options.length; j++) {
                if (element.options[j].selected != element.options[j].defaultSelected) {
                    return true;
                }
            }
        }
    }
    return false;
}


检查form表单数据是否发生变化

最近做了些前端的东西,很久没碰js了,所以小结一下这两天碰到的问题 1、检查form表单数据是否发生变化 这里我用的是比较默认值的方法 不需要为了复杂的事件处理而写过多的废话,每个表单元素都有与...
  • u010933908
  • u010933908
  • 2016年03月03日 17:49
  • 3443

form的text设置默认值

有时候我们在修改信息的时候,要跳转到一个页面,其实就是一个form,里面有te...
  • wtt561111
  • wtt561111
  • 2014年05月10日 09:54
  • 2517

AngularJS表单操作几个例子(表单提交,表单编辑默认值)

听同事讲AngularJS比jquery还要强大一些于时就开始了AngularJS学习工作,但在学习AngularJS中发现对于表单提交与表单默认值都不会搞,下面来看看几个关于AngularJS Fo...
  • konglongaa
  • konglongaa
  • 2017年03月09日 10:27
  • 3315

一步步学习微软InfoPath2010和SP2010--第五章节--添加逻辑和规则到表单(3)--使用函数设置默认值

现在你将使用一些InfoPath函数来给Blue Yonder采购表单默认视图添加更多逻辑。你将在本例中使用的公式是concat和now。...
  • u012025054
  • u012025054
  • 2014年03月30日 11:37
  • 1363

使用隐藏域input,提交表单未设置默认值,提交报错400

1、 html表单如下: 红色为正确代码,蓝色为出错代码 班组/个人进退场记录 selected style="width:60px">班组 selec...
  • zlsdmx
  • zlsdmx
  • 2016年12月15日 14:59
  • 627

Form表单中默认值的改变(switch、for中使用break)

最近修改一个js函数,却发现自己需要学习的还很多 函数的主要目的是想知道form表单中的值有没有被改变,原来的函数采用的是if…else/if结构,在这里,我还是把代码贴出来吧: //函数; f...
  • blueling51
  • blueling51
  • 2011年11月11日 09:37
  • 1680

菜鸟的jquery学习笔记,jquery输入框添加默认值,jquery提交表单,jquery获取字符串长度,并截取字符串

1,jquery输入框添加默认值 因为要保持页面中查询的条件不变,所以将条件提交到action后再封装到对应的bean中,然后再传回到查询页面,用jquery给表单填值。其中bean的值通过el表达...
  • fengspg
  • fengspg
  • 2012年05月01日 20:52
  • 7358

前端笔记1(表单默认值)

默认值: 隐式:隐藏域(HTML DOM Hidden 对象) 如果想要提交并非用户直接输入的数据的话,就是用这种类型的元素。 http://www.runoob.com/jsref/dom-obj...
  • hermittt
  • hermittt
  • 2016年05月25日 23:57
  • 813

检测form表单是否有被修改

之前我遇到过在form表单提交前让我用js检测一下form表单的元素是否有被修改过,若没有被修改过,则不提交表单;若有更新项,才提交。 在网上翻阅了一番之后,自己整理了一下。不多说,上代码(ps.记住...
  • sinat_18755913
  • sinat_18755913
  • 2015年11月26日 16:10
  • 232

js 验证表单中的值是否改变

  • 2013年12月31日 09:31
  • 2KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:设置表单的默认值、检测表单是否变更
举报原因:
原因补充:

(最多只允许输入30个字)