设置表单的默认值、检测表单是否变更
2015-11-19 14:32
190 查看
通过动态加载表单内容,要求检测加载之后有没有变更过,可以通过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; }
相关文章推荐
- Remove Invalid Parentheses--Nice
- 用eclipse导入design需要注意的细节
- JS实现——Base64编码解码,带16进制显示
- java入门 第三季4
- 用rm递归删除子目录下所有.o后缀文件
- 磁盘同步rsync+sersync
- Xcode7 免证书真机调试
- MYSQL中limit的使用
- java入门 第三季3
- 。鸟哥私房菜
- AFNetWork 简单实用demo
- CentOS yum安装redis(转)
- java中的路径
- php四种基础算法:冒泡,选择,插入和快速排序法
- 你爱我吗?如何利用BRAT进行中文情感分析语料标注掌握玩家心声
- 较好的类名命名规则
- hive使用技巧(二)——共享中间结果集
- 树、森林及二叉树的相互转换 – 数据结构和算法50
- Java如何判断socket是否已经断开
- 指针遇到的问题,请指教