zoukankan      html  css  js  c++  java
  • hidden表单值无法重置的缺陷

    在项目开发过程中发现form表单控件中的hidden表单组件无法被form自带的reset函数重置未默认值所以针对hidden组件进行以下测试代码如下 :

    <!DOCTYPE html>
    <html>
    
    <head>
        <meta charset="utf-8">
        <title>Test</title>
    </head>
    
    <body>
        <form id="form1" action="">
            <input id="hidden1" type="hidden" value="DefaultValue">
            <input id="text1" type="text">
            <button  type="button" onclick="changeHiddenValue()">改变hidden表单的值</button>
            <button  type="button" onclick="getHiddenValue()">获取hidden表单的值</button>
            <button  type="button"  onclick="getHiddenValueAttribute()">获取hidden表单中默认的value属性的值</button>
            <button  type="button"  onclick="resetHidden()">重置hidden表单</button>
            <button  type="reset">重置</button>
        </form>
        <script>
            (function(){ 
                getHiddenValue();
            })();
    
            function changeHiddenValue(){ 
                var text = document.getElementById('text1');
                var hidden = document.getElementById('hidden1');
                hidden.value = text.value
            }
            function getHiddenValue(){ 
                var text = document.getElementById('text1');
                var hidden = document.getElementById('hidden1');
                text.value = hidden.value;
            }
            function resetForm(){ 
                var form = document.getElementById("form1");
                form.reset();
                getHiddenValue();
            }
            function getHiddenValueAttribute(){ 
                var text = document.getElementById('text1');
                var hidden = document.getElementById('hidden1');
                alert(hidden.getAttribute("value"));
                text.value = hidden.getAttribute("value");
            }
        </script>
    </body>
    
    </html>
    

    测试结果是,form表单自带的reset方法以及type的reset的button均存在无法重置hidden表单的值的bug;故进行form重置时要对hidden表单进行特殊处理,使其恢复默认值


    如何解决这个缺陷

    其实可以依赖各种不同的form插件等插件内部的form表单的reset方法其实已经针对这个缺陷进行了一定程度的修复
    jquery.form.js是一个全面支持表单的jQuery插件
    其中包含了以下方法

    • clearForm(includeHidden)
    • clearFields(includeHidden)
    • clearInputs(includeHidden)

    其中内部勉强可以将hidden表单清空,但是依旧无法对hidden表单进行重置,使其恢复默认值

  • 相关阅读:
    20162329张旭升 2017-2018-2 《程序设计与数据结构》第一周学习总结
    20162329 张旭升2016-2017《程序设计与数据结构》课程总结
    实验报告五
    20162329 张旭升 阶段四则运算(挑战出题)
    实验四:Android 开发基础
    四则运算的整体总结(第二周)
    结对编程四则运算(阶段总结)
    团队项目-选题报告
    第二次结对编程作业
    第一次结对编程作业
  • 原文地址:https://www.cnblogs.com/linbingcheng/p/6804527.html
Copyright © 2011-2022 走看看