`

JQuery-Form表单中默认值的改变

阅读更多

最近修改一个 js 函数,却发现自己需要学习的还很多

函数的主要目的是想知道 form 表单中的值有没有被改变,原来的函数采用的是 if…else/if 结构,在这里,我还是把代码贴出来吧:

// 函数 ;

function IsFormChanged(name) {

       var isChanged = false;

//     var form = document.getElementById(name);

       var form = document.forms[name];

       for (var i = 0; i < form.elements.length; i++) {

              var element = form.elements[i];

              var type = element.type;

              if (type == "text" || type == "hidden" || type == "textarea" || type == "button") {

                     if (element.value != element.defaultValue) {

                            isChanged = true;

                            alert("1");

                            break;

                     }

              } else if (type == "radio" || type == "checkbox") {

                     if (element.checked != element.defaultChecked) {

                            isChanged = true;

                            alert("2");

                            break;

                     }

              } 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) {

                                   isChanged = true;

                                   alert("3");

                                   break;

                            }

                     }

              } else {

                     // etc...

              }     

       }   

       alert( isChanged?" 你改变了表单的默认值 ":" 表单的值没有改变 ");

       return isChanged;

}

       这个函数思路很清晰了,但是,我准备采用另外一个方式来重写它,我采用的是 switch ,于是,一开始,我把 if…else/if 都改成 switch ,可是,发现不能验证,后来,我发现了: for 循环中使用 switch ,然后用 break 的话,退出来的是 switch 结构,循环还要继续的,而我需要的是直接退回 for 循环。上网找了一些解决办法,最后发现把 switch 部分的分离出来单独写成一个函数比较好,但是,考虑到这个函数最终只会在一个函数中使用,就是我们的判断 form 表单默认值的函数,而且,由于项目开发的需要,我把一些公用的函数都封装起来,所以,最后我把函数改写成了如下的形式:

       var Form={

       IsFormChanged:function(id){

       /*IsFormChangedCase 这个函数我本来是放在外面的,和 IsFormChanged 的级别是一样的,但是现在只有 IsFormChanged 这个函数使用这个,其原因是因为 switch for 中都是用 break 的缘故,所以,我最终把这个函数作为 IsFormChanged 函数的一个变量来使用。

       */

              var IsFormChangedCase=function(element){

              var isChanged = false;

              switch(element.type){

                     case "text":

                     case "hidden":

                     case "textarea":

                     case "button":

                            if(element.value != element.defaultValue)

                                   isChanged= true;

                            break;

                     case "radio":

                     case "checkbox":

                            if(element.checked != element.defaultChecked)

                                   isChanged= true;

                            break;

                     case "select-one":

                     case "select-multiple":

                            for (var j = 0; j < element.options.length; j++){

                                   if(element.options[j].selected != element.options[j].defaultSelected){

                                          isChanged= true;

                                          break;

                                   }

                            }

                            break;

                     }

                     return isChanged;  

              };

              var str=false;

              var form = document.getElementById(id);

              for (var i = 0; i < form.elements.length; i++){

                     var element = form.elements[i];

                     if(IsFormChangedCase(element)){

                            str=true;

                            break;

                     }

              }

              return str;      

       }

}

// 这个只是测试函数

function test()

{

       var ret=Form.IsFormChanged("frm2");

       alert( ret?" 你改变了表单的默认值 ":" 表单的值没有改变 ");

       return ret;

}

 

http://www.codestore.net/store.nsf/unid/DOMM-4UTKE6

分享到:
评论

相关推荐

    【开源】jQuery oform beta 0.1.5 - form 表单美化插件源代码

    jQuery oform beta 0.1.5 - form 表单美化插件源代码 版权:zhang yang soft 交流E-Mail:oceancode@163.com 浏览器支持:IE、Firefox、Opera , google chrome (谷歌) 版本说明: 1. beta 0.1.0 版 支持input...

    【开源】jQuery oform beta 0.1.7 - form 表单美化插件源代码

    版权:zhang yang soft ...浏览器支持:IE、Firefox、Opera , google chrome (谷歌) 版本说明: 1. beta 0.1.0 版 支持input text/button 美化 时间:2010-01-25 ...jquery oform 美化 插件 开源

    jQuery EasyUI API 中文文档 - Form表单

    下面,我们将详细解读jQuery EasyUI API中文文档中关于Form表单的知识点。 首先,了解如何将一个普通的HTML表单转化为一个支持Ajax提交的表单。这可以通过为表单元素绑定jQuery EasyUI的Form插件来实现。例如,首先...

    jquery控制表单输入框显示默认值的方法

    在本文中,我们将深入探讨如何使用jQuery来控制表单输入框(`&lt;input&gt;`元素)显示默认值的方法。这个功能在很多场景下都非常实用,比如创建提示性文本,当用户聚焦输入框时自动清除,失去焦点且未输入内容时恢复...

    jQuery ajax提交Form表单实例(附demo源码)

    本文将详细讲解如何使用jQuery的`$.ajax`方法来提交Form表单,以及如何通过自定义函数实现更灵活的表单提交。 首先,传统的HTML Form表单提交会导致页面刷新,用户体验不佳。为了实现无刷新提交,我们可以利用...

    jquery-easyui-1.3.2 DEMO API 配置文件

    这些示例涵盖了EasyUI的各个组件,从基础的按钮(Button)到复杂的表单(Form)和数据管理(DataGrid)。通过实际操作,我们可以直观地看到组件的使用方法、样式调整和事件绑定,这对于初学者来说是极其宝贵的资源。...

    jquery-formtips:一个 jQuery 插件,使表单能够将默认值或消息绘制到 inputtextarea 元素中

    它使表单能够将默认值或消息绘制到 input/textarea 元素中。 文本是从元素的标题属性中获取的。 我怎样才能使用这个插件? 当然,首先您需要当前版本的 jQuery 库。 转到 jQuery 网站并获取一份副本。 接下来,...

    jquery-1.1.3 效率提高800%

    在jQuery 1.2版本中,如果你指明了一个JSONP回调函数,你就可以从其它的域中载入JSON类型的数据,写法类似于 "myurl?callback=?" 。jQuery会自动调用正确的方法名称来代替查询字符串,执行你指定的回调函数。...

    jQuery复制移除表单元素代码.zip

    在网页开发中,jQuery是一个非常流行的JavaScript库,它极大地简化了DOM操作、事件处理、动画效果和Ajax交互。"jQuery复制移除表单元素代码.zip"这个资源包含了一个使用jQuery 1.7.2版本实现的功能,即动态复制和...

    jQuery实现form表单元素序列化为json对象的方法

    ### jQuery实现form表单元素序列化为json对象的方法 首先,需要理解jQuery中的`serializeArray()`方法。该方法可以序列化表单元素(form),返回一个包含表单值的键值对数组,其中键是输入字段的name属性,值则是...

    form表单日期输入控件

    在网页设计和开发中,`form` 表单是用户与服务器进行数据交互的重要组成部分,而日期输入控件则是表单中常见的一种元素,用于收集用户的日期或时间信息。在HTML5中,引入了内置的日期输入类型,使得创建和处理日期...

    dust-ajaxForm:一个 jQuery 插件,用于添加 ajax-ify 表单

    用于添加 ajax-ify 表单的 jQuery 插件。 它能做什么 你有一个表格。 提交表单时,您需要进行一些 PHP 处理,但您不想离开页面。 该插件使用 ajax 提交表单,返回响应,并相应地调用成功、失败和工作方法。 所以它...

    使用jQuery给input标签设置默认值

    通过本文的示例,我们可以利用jQuery的选择器功能`.forminput`来选取所有的`class="forminput"`的input元素,并使用`.each()`方法迭代每个元素,调用`.setDefauleValue`方法来设置它们的默认值。 ### 总结 使用...

    jQuery ui input滑动条制作房屋表单搜索条件滑动条

    本文将深入探讨如何利用jQuery UI中的input滑动条功能来创建一个房屋表单搜索条件的滑动条。通过这个功能,用户可以更直观地调整和选择他们对房屋搜索的特定条件,例如价格范围、房间数量等。 首先,我们需要在项目...

    jquery-ajax-validation

    jQuery AJAX表单验证 预期数据格式 { " success " : false , " errors " : { " email " : [ " Email is not valid " ], " password " : [ " Password is not valid " , " Password is too short " ] } } 选项 ...

    json-editor:一个将JSON模式转换为表单的jquery插件

    它仅取决于jQuery。 可以在拖曳模式下使用:属性网格(当前实现)/常规形式(路线图)。 易于自定义CSS。 支持的输入:text / checkbox / textarea / html / color / date / number / radio / select。 验证...

    jquery.validate表单验证框架详解.docx

    在本文中,我们将深入探讨jQuery Validate的一些关键功能和用法。 首先,我们需要引入jQuery库以及jQuery Validate插件的JavaScript文件。在HTML文档的`&lt;head&gt;`或`&lt;body&gt;`部分,我们可以添加如下代码: ```html ...

Global site tag (gtag.js) - Google Analytics