有一个form表单,要用AJAX后台提交,原来想拼接json,但是数据多了麻烦,不灵活。

用HTML5的FormData来初始化表单

  1. var formdata=new FormData(document.getElementById("advForm"));

看似还可以,但发现有两个问题,

一,formdata.get()方法不知为什么用不了

二,Form Data 数据格式不如Jq的简洁,

  1. WebKitFormBoundary29h06FRZequJgQtR
  1. var stu={
  2. name:"冷荣富",
  3. age:22,
  4. sex:"男"
  5. };
  6. $.ajax({
  7. type : "POST", //提交方式
  8. url : "http://localhost/jsonTest.php",//路径,www根目录下
  9. data : {
  10. "student" : stu
  11. },//数据,这里使用的是Json格式进行传输
  12. success : function(result) {//返回数据根据结果进行相应的处理
  13. alert(result);
  14. }
  15. });

这段JQ提交的数据是序列化的

网查如然不用我造轮子了,转一个可用的

使用原生的js模拟了表单序列化,代码中对表单处理尽可能地进行文字说明 
其中对于url,字段名称,中文进行了使用了encodeURIComponent()进行编码。

  1. Object.prototype.serialize = function(){
  2. var res = [], //存放结果的数组
  3. current = null, //当前循环内的表单控件
  4. i, //表单NodeList的索引
  5. len, //表单NodeList的长度
  6. k, //select遍历索引
  7. optionLen, //select遍历索引
  8. option, //select循环体内option
  9. optionValue, //select的value
  10. form = this; //用form变量拿到当前的表单,易于辨识
  11.  
  12. for(i=0, len=form.elements.length; i<len; i++){
  13.  
  14. current = form.elements[i];
  15.  
  16. //disabled表示字段禁用,需要区分与readonly的区别
  17. if(current.disabled) continue;
  18.  
  19. switch(current.type){
  20. //可忽略控件处理
  21. case "file": //文件输入类型
  22. case "submit": //提交按钮
  23. case "button": //一般按钮
  24. case "image": //图像形式的提交按钮
  25. case "reset": //重置按钮
  26. case undefined: //未定义
  27. break;
  28. //select控件
  29. case "select-one":
  30. case "select-multiple":
  31. if(current.name && current.name.length){
  32. console.log(current)
  33. for(k=0, optionLen=current.options.length; k<optionLen; k++){
  34. option = current.options[k];
  35. optionValue = "";
  36. if(option.selected){
  37. if(option.hasAttribute){
  38. optionValue = option.hasAttribute('value') ? option.value : option.text
  39. }else{
  40. //低版本IE需要使用特性 的specified属性,检测是否已规定某个属性
  41. optionValue = option.attributes('value').specified ? option.value : option.text;
  42. }
  43. }
  44. res.push(encodeURIComponent(current.name) + "=" + encodeURIComponent(optionValue));
  45. }
  46. }
  47. break;
  48.  
  49. //单选,复选框
  50. case "radio":
  51. case "checkbox":
  52. //这里有个取巧 的写法,这里的判断是跟下面的default相互对应。
  53. //如果放在其他地方,则需要额外的判断取值
  54. if(!current.checked) break;
  55.  
  56. default:
  57. //一般表单控件处理
  58. if(current.name && current.name.length){
  59. res.push(encodeURIComponent(current.name) + "=" + encodeURIComponent(current.value));
  60. }
  61. }
  62. }
  63. return res.join("&");
  64. }

对HTML表单使用:

  1. formElement.serialize();

得到类似如下结果:a=1&b=2&c=3&d=4&e=5

相关链接:https://blog.csdn.net/qq_35087256/article/details/81253559

原生JS实现表单序列化serialize()的更多相关文章

  1. form 表单序列化 serialize

    在开发中有时需要在js中提交form表单数据,就需要将form表单进行序列化. jquery提供的serialize方法能够实现. $("#searchForm").seriali ...

  2. 原生js的表单验证

    最近在学原生的js,把一些练手的代码往博客放一放,权当积累经验,若有错漏,或是觉得浅显,大家不要见怪. 这是一个原生js编写的简单的表单验证: <!DOCTYPE html><htm ...

  3. 原生JS写表单验证提交功能

    先上效果图: 表单的基础内容就是昵称判断.手机号判断.邮箱判断.身份证号码判断,这里是用到正则验证检验格式. 页面的表单写法就是一个form的提交.输入框用input来实现,输入内容用value来获取 ...

  4. 原生js制作表单验证,基本的表单验证方法

    表单验证是web前端最常见的功能之一,也属于前端开发的基本功.自己完成一个表单验证的开发,也有助于加深对字符串处理和正则表达式的理解. 基本的表单验证包括如:字母验证.数字验证.字母和数字验证.汉字验 ...

  5. 原生js提交表单

    /********************* 表单提交 ***********************/ function ajax(options) { options = options || { ...

  6. 原生js阻止表单跳转

    /* W3C浏览器下的 */ var forms = document.getElementById("from") forms.addEventListener('submit' ...

  7. js实现表单序列化的两种方法。

    function serialize(form) { var parts = [], elems = form.elements, i = , len = elems.length, filed = ...

  8. (转)jquery serialize表单序列化,当radio或checkbox 未选中时,没有序列化到对象中的原因分析和解决方案 - ghostsf

    相信很多人都用过jq的表单序列化serialize()方法,因为这能很方便地帮你把表单里所有的非禁用输入控件序列化为 key/value 对象,不需要你再去一个个地拼接参数了. 这是一个很好用的函数, ...

  9. 原生js实现form表单序列化

    当我们有form表单而且里面的表单元素较多时,咱们总不能一个个去获取表单元素内的值来进行拼接吧!这样会很让人蛋疼!为了方便与后台交互并且提高自己的开发效率,并且不让你蛋疼:我们一起用原生来写一个表单序 ...

随机推荐

  1. 归并排序&&归并排序求逆序对

    归并排序 归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide and Conquer)的一个非常典型的应用.将已有序的子序列合并,得到完全有序的序 ...

  2. Json.NET Performance Tips

    原文: http://www.newtonsoft.com/json/help/html/Performance.htm To keep an application consistently fas ...

  3. jQuery (02) 重点知识点总结

    jQuery 如果用户未登录,当加入购物车,会将商品相关信息存入 cookie 或者 session,这两个都是可以标识用户信息的东西 是一个 JavaScript 库,封装了常用的开发功能,和一些需 ...

  4. mobile_缩放

    document.documentElement.clientWidth       不包含滚动条 window.innerWidth                                  ...

  5. oracle统计数据时,涉及两个表的数据

    SELECT t1.*,a.num FROM (SELECT SUM(t.total_profit) total_profit, SUM(t.main_business_income) main_bu ...

  6. Magic Pen 6

    Problem Description In HIT, many people have a magic pen. Lilu0355 has a magic pen, darkgt has a mag ...

  7. 引用:使用grunt 压缩 合并js、css文件

    引用:https://www.jianshu.com/p/08c7babdec65 压缩 js 文件 1.创建一个目录 名为grunt   目录.png 2.在grunt目录下创建一个 src目录,存 ...

  8. jQuery地图插件jVectorMap的简单使用

    1.官网下载jVectorMap插件压缩文件 官网地址:http://www.jvectormap.com/ 2.解压文件包括jVectorMap库及基础样式表,编写Html文件,引入jQuery框架 ...

  9. NoSQL入门

    NoSQL(Not Only SQL)入门: *没有Fixed Schema *没有关系型数据储存在系统中 * 在大数据方面NoSQL有更好的表现 * 支持unstructured data - 不同 ...

  10. 有几个PAT

    描述 字符串APPAPT中包含了两个单词“PAT”,其中第一个PAT是第2位(P),第4位(A),第6位(T):第二个PAT是第3位(P),第4位(A),第6位(T). 现给定字符串,问一共可以形成多 ...