• 鄂州重拳治理“散乱污”企业 半年内关停数量比过去两年还多 2019-06-15
  • 【华商侃车NO.192】 亲!楼市火爆,别忘了买车位啊! 2019-06-15
  • 学习领会党的十九大报告需要准确把握的几个重大问题 2019-06-09
  • 飞行员夜间海上实弹射击 导弹全部命中目标 2019-06-07
  • 武警重庆总队举行干部退役仪式 2019-06-06
  • 香港大学发现有效对抗流感病毒的新方法 2019-06-05
  • 一语惊坛(6月15日):人民日报和共和国共同成长。 2019-06-05
  • 人的本质,要能反映出人与动物的本质不同。过去有个网友说“劳动是人的本质”;真理先生现说是“财富占有”!???,能解释一下么? 2019-06-04
  • 点击天山网 掌握全新疆 2019-06-04
  • 端午小长假各大文化场馆火热迎客 文化游成市民游客假期“心头好” 2019-05-31
  • 肉毒梭菌感染相关新闻 2019-05-31
  • 姚明撰文回忆菜鸟赛季 温暖的回忆感谢弗朗西斯 2019-05-26
  • 遵义师范学院副校长颜永强:长征为军队建设提供三方面宝贵经验 2019-05-23
  • 劲爆福利 昨日中奖名单公布 今日5大箱可乐任意送劲爆福利-等级 2019-05-22
  • 风水神话更危险的事,就是眼瞎,根本分不清谁对谁, 2019-05-22
  • Jquery中文网 南粤风采36选7开奖公告 www.77402m.com
    Jquery中文网 >  脚本编程  >  javascript  >  正文 JavaScript表单序列化的方法详解

    南粤36选7开奖号码:JavaScript表单序列化的方法详解

    发布时间:2015-01-26   编辑:南粤风采36选7开奖公告 www.77402m.com
    本文介绍下,在javascript中实现表单序列化的方法,通过实例加深理解,有需要的朋友参考下吧。

    南粤风采36选7开奖公告 www.77402m.com 在JavaScript中,可以利用表单字段的type属性,连同name和value属性一起实现对表单的序列。

    首先,我们来了解下在表单提交期间,浏览器是怎样将数据发送给服务器的。
    对表单字段的名称和值进行URL编码,使用和号(&)分割。
    不发送禁用的表单字段。
    只发送勾选的复选框和单选按钮。
    不发送type为“reset”和“button”的按钮。
    多选择框中的每个选中的值单独一个条目。
    在单击提交按钮提交表单的情况下,也会发送提交按钮;
    否则,不发送提交按钮。也包括type为“image”的<input>元素。
    <select>元素的值,就是选中的<option>元素的value特性的值。如果<option>元素没有value特性,则是<option>元素的文本值。
    在表单序列化过程中,一般不包含任何按钮字段,因为结果字符串很可能是通过其它方式提交的。
    除此之外的其它上述规则都应该遵循。

    实现表单序列化的代码:
     

    function serialize(form) {
        var parts = [],
            field = null,
            i,
            len,
            j,
            optLen,
            option,
            optValue;
    
        for (i = 0, len = form.elements.length; i < len; i++) {
            field = form.elements[i];
    
            switch (field.type) {
            case "select-one":
            case "select-multiple":
    
                if (field.name.length) {
                    for (j = 0, optLen = field.options.length; j < optLen; j++) {
                        option = field.options[j];
                        if (option.selected) {
                            optValue = "";
                            if (option.hasAttribute) {
                                optValue = (option.hasAttribute("value") ? option.value : option.text);
                            } else {
                                optValue = (option.attributes["value"].specified ? option.value : option.text);
                            }
                            parts.push(encodeURIComponent(field.name) + "=" + encodeURIComponent(optValue));
                        }
                    }
                }
                break;
    
            case undefined:
                //字段集
            case "file":
                //文件输入
            case "submit":
                //提交按钮
            case "reset":
                //重置按钮
            case "button":
                //自定义按钮
                break;
    
            case "radio":
                //单选按钮
            case "checkbox":
                //复选框
                if (!field.checked) {
                    break;
                }
                /* 执行默认曹旭哦 */
    
            default:
                //不包含没有名字的表单字段
                if (field.name.length) {
                    parts.push(encodeURIComponent(field.name) + "=" + encodeURIComponent(field.value));
                }
            }
        }
        return parts.join("&");
    }
    
    var btn = document.getElementById("serialize-btn");
    EventUtil.addHandler(btn, "click", function (event) {
        var form = document.forms[0];
        alert(serialize(form));
    });

    上面这个serialize()函数首先定义了一个名为parts的数组,用于保存将要创建的字符串的各个部分。

    然后,通过for循环迭代每个表单字段,并将其保存在field变量中。在获得了一个字段的引用之后,使用switch语句检测其type属性。序列化过程最麻烦的就是<select>元素,它可能是单选框也可能是多选框,值可能有一个选中项,而多选框则可能有零或多个选中项。这里的代码适用于这两种选择框,至于可选框的数量是由浏览器控制的。在找到了一个选中项之后,需要确定使用什么值。如果不存在value特性,或者虽然存在该特性,但值为空字符串,都要使用选项的文本代替。为检查这个特性,在DOM兼容的浏览器中需要使用hasAttribute()方法,而在IE中需要使用特性的specified属性。

    如果表单中包含<fieldset>元素,则该元素会出现在元素集合中,但没有type属性。因此,如果type属性未定义,则不需要对其进行序列化。同样,对于各种按钮以及文件输入字段也是如此。对于单选按钮和复选框,要检查其checked属性是否被设置为false,如果是则退出switch语句。如果checked属性为ture,则继续执行default语句,即将当前字段的名称和值进行编码,然后添加到parts数组中。函数的最后一步,就是使用join()格式化整个字符串,也就是用和号来分割每一个表单字段。

    最后,serialize()函数会以查询字符串的格式输出序列化之后的字符串。

    您可能感兴趣的文章:
    探讨JQUERY JSON的反序列化类 using问题的解决方法
    jquery将一个表单序列化为一个对象的方法
    jquery ajax跨域解决方法(json方式)
    jQuery中使用Ajax获取JSON格式数据示例代码
    基于jquery异步传输json数据格式实例代码
    jQuery中验证表单提交方式及序列化表单内容的实现
    jquery ajax中使用jsonp的限制解决方法
    jquery教程ajax请求json数据示例
    jQuery-serialize()输出序列化form表单值的方法
    jQuery插件jQuery-JSONP开发ajax调用使用注意事项

    [关闭]
  • 鄂州重拳治理“散乱污”企业 半年内关停数量比过去两年还多 2019-06-15
  • 【华商侃车NO.192】 亲!楼市火爆,别忘了买车位啊! 2019-06-15
  • 学习领会党的十九大报告需要准确把握的几个重大问题 2019-06-09
  • 飞行员夜间海上实弹射击 导弹全部命中目标 2019-06-07
  • 武警重庆总队举行干部退役仪式 2019-06-06
  • 香港大学发现有效对抗流感病毒的新方法 2019-06-05
  • 一语惊坛(6月15日):人民日报和共和国共同成长。 2019-06-05
  • 人的本质,要能反映出人与动物的本质不同。过去有个网友说“劳动是人的本质”;真理先生现说是“财富占有”!???,能解释一下么? 2019-06-04
  • 点击天山网 掌握全新疆 2019-06-04
  • 端午小长假各大文化场馆火热迎客 文化游成市民游客假期“心头好” 2019-05-31
  • 肉毒梭菌感染相关新闻 2019-05-31
  • 姚明撰文回忆菜鸟赛季 温暖的回忆感谢弗朗西斯 2019-05-26
  • 遵义师范学院副校长颜永强:长征为军队建设提供三方面宝贵经验 2019-05-23
  • 劲爆福利 昨日中奖名单公布 今日5大箱可乐任意送劲爆福利-等级 2019-05-22
  • 风水神话更危险的事,就是眼瞎,根本分不清谁对谁, 2019-05-22