深入分析JSON编码格式提交表单数据


Posted in Javascript onJune 25, 2015

 以JSON编码格式提交表单数据是HTML5对WEB发展进化的又一大贡献,以前我们的HTML表单数据是通过key-value方式传输的服务器端,这种形式的传输对数据组织缺乏管理,形式十分原始。而新出现的JSON格式提交表单数据方法,将表单里的所有数据转化的具有一定规范的JSON格式,然后传输的服务器端。服务器端接收到的数据是直接可以使用的合格JSON代码。

 如何声明以JSON格式提交表单

大家应该对如何用表单上传一个文件的写法很熟悉,它需要在HTML中form标记上添加 enctype="multipart/form-data" 声明,就是告诉浏览器要按上传文件模式发送表单数据。而JSON格式提交表单的声明与此类似,它的写法是: enctype='application/json'。

 对老式浏览器的兼容

以JSON格式提交表单是HTML5中一种很新的规范,只有实现了这些规范的现代浏览器才能识别 enctype='application/json'的语义,才能正确的将表单数据打包成JSON格式。而对于一些老式浏览器,以及还未实现这些标准的浏览器,它们无法识别 enctype='application/json'代表什么,于是表单的enctype会自动退化成application/x-www-form-urlencoded缺省编码格式。服务器端代码可以根据enctype的值来判断如何接收数据。

 JSON编码格式提交表单的格式范例

例1 基本用法

<form enctype='application/json'>
 <input name='name' value='Bender'>
 <select name='hind'>
  <option selected>Bitable</option>
  <option>Kickable</option>
 </select>
 <input type='checkbox' name='shiny' checked>
</form>

// 生成的Json数据是
{
 "name":  "Bender"
, "hind":  "Bitable"
, "shiny": true
}

例2 当表单存在多个重名的表单域时,按JSON数组编码

<form enctype='application/json'>
 <input type='number' name='bottle-on-wall' value='1'>
 <input type='number' name='bottle-on-wall' value='2'>
 <input type='number' name='bottle-on-wall' value='3'>
</form>

// 生成的Json数据是
{
 "bottle-on-wall":  [1, 2, 3]
}

例3 表单域名称以数组形成出现的复杂结构

<form enctype='application/json'>
 <input name='pet[species]' value='Dahut'>
 <input name='pet[name]' value='Hypatia'>
 <input name='kids[1]' value='Thelma'>
 <input name='kids[0]' value='Ashley'>
</form>

// 生成的Json数据是
{
  "pet": {
    "species": "Dahut"
  ,  "name":   "Hypatia"
  }
,  "kids":  ["Ashley", "Thelma"]
}

例4 在上面的例子中,缺失的数组序号值将以null替代

<form enctype='application/json'>
 <input name='hearbeat[0]' value='thunk'>
 <input name='hearbeat[2]' value='thunk'>
</form>

// 生成的Json数据是
{
  "hearbeat":  ["thunk", null, "thunk"]
}

例5 多重数组嵌套格式,嵌套层数无限制

<form enctype='application/json'>
 <input name='pet[0][species]' value='Dahut'>
 <input name='pet[0][name]' value='Hypatia'>
 <input name='pet[1][species]' value='Felis Stultus'>
 <input name='pet[1][name]' value='Billie'>
</form>

// 生成的Json数据是
{
 "pet": [
  {
   "species": "Dahut"
  , "name":  "Hypatia"
  }
 , {
   "species": "Felis Stultus"
  , "name":  "Billie"
  }
 ]
}

例6 真的,没有数组维度限制!

<form enctype='application/json'>
 <input name='wow[such][deep][3][much][power][!]' value='Amaze'>
</form>

// 生成的Json数据是
{
 "wow": {
  "such": {
   "deep": [
    null
   , null
   , null
   , {
     "much": {
      "power": {
       "!": "Amaze"
      }
     }
    }
   ]
  }
 }
}

例7 文件上传

<form enctype='application/json'>
 <input type='file' name='file' multiple>
</form>

// 假设你上传了2个文件, 生成的Json数据是:
{
 "file": [
  {
   "type": "text/plain",
   "name": "dahut.txt",
   "body": "REFBQUFBQUFIVVVVVVVVVVVVVCEhIQo="
  },
  {
   "type": "text/plain",
   "name": "litany.txt",
   "body": "SSBtdXN0IG5vdCBmZWFyLlxuRmVhciBpcyB0aGUgbWluZC1raWxsZXIuCg=="
  }
 ]
}
Javascript 相关文章推荐
JavaScript 面向对象的 私有成员和公开成员
May 13 Javascript
jquery实现树形二级菜单实例代码
Nov 20 Javascript
js防止页面被iframe调用的方法
Oct 30 Javascript
基于JavaScript实现文字超出部分隐藏
Feb 29 Javascript
jquery实现全选、不选、反选的两种方法
Sep 06 Javascript
基于JS代码实现简单易用的倒计时 x 天 x 时 x 分 x 秒效果
Jul 13 Javascript
JavaScript 判断iPhone X Series机型的方法
Jan 28 Javascript
vue项目移动端实现ip输入框问题
Mar 19 Javascript
如何使用JavaScript实现栈与队列
Jun 24 Javascript
JavaScript实现PC端四格密码输入框功能
Feb 19 Javascript
jQuery实现可以计算进制转换的计算器
Oct 19 jQuery
Vue深入理解插槽slot的使用
Aug 05 Vue.js
jquery移动点击的项目到列表最顶端的方法
Jun 24 #Javascript
jquery使整个div区域可以点击的方法
Jun 24 #Javascript
jQuery寻找n以内完全数的方法
Jun 24 #Javascript
js实现仿阿里巴巴城市选择框效果实例
Jun 24 #Javascript
Javascript常用小技巧汇总
Jun 24 #Javascript
js实现的倒计时按钮实例
Jun 24 #Javascript
js实现大转盘抽奖游戏实例
Jun 24 #Javascript
You might like
一段php加密解密的代码
2006/10/09 PHP
destoon找回管理员密码的方法
2014/06/21 PHP
php中注册器模式类用法实例分析
2015/11/03 PHP
PHP入门教程之面向对象的特性分析(继承,多态,接口,抽象类,抽象方法等)
2016/09/11 PHP
Javascript继承机制的设计思想分享
2011/08/28 Javascript
用Javascript评估用户输入密码的强度(Knockout版)
2011/11/30 Javascript
由点击页面其它地方隐藏div所想到的jQuery的delegate
2013/08/29 Javascript
jQuery插件分享之分页插件jqPagination
2014/06/06 Javascript
js 左右悬浮对联广告代码示例
2014/12/12 Javascript
基于jquery animate操作css样式属性小结
2015/11/27 Javascript
Bootstrap开关(switch)控件学习笔记分享
2016/05/30 Javascript
javascript 数据存储的常用函数总结
2017/06/01 Javascript
利用JS做网页特效_大图轮播(实例讲解)
2017/08/09 Javascript
完美解决axios在ie下的兼容性问题
2018/03/05 Javascript
inquirer.js一个用户与命令行交互的工具详解
2019/05/18 Javascript
jquery插件开发模式实例详解
2019/07/20 jQuery
Vue初始化中的选项合并之initInternalComponent详解
2020/06/11 Javascript
微信小程序实现翻牌抽奖动画
2020/09/21 Javascript
Python3 中把txt数据文件读入到矩阵中的方法
2018/04/27 Python
python中的常量和变量代码详解
2018/07/25 Python
python绘制中国大陆人口热力图
2018/11/07 Python
python 实现selenium断言和验证的方法
2019/02/13 Python
利用python实现PSO算法优化二元函数
2019/11/13 Python
Python定时从Mysql提取数据存入Redis的实现
2020/05/03 Python
python 利用panda 实现列联表(交叉表)
2021/02/06 Python
HTML5图片预览实例分享
2014/06/04 HTML / CSS
html5开发三八女王节表白神器
2018/03/07 HTML / CSS
Nike台湾官方商店:Nike.com (TW)
2017/08/16 全球购物
Merrell美国官网:美国登山运动鞋品牌
2018/02/07 全球购物
工作自我评价分享
2013/12/01 职场文书
婚前协议书怎么写
2014/04/15 职场文书
法人委托书范本格式
2014/09/15 职场文书
单位工作证明书格式
2014/10/04 职场文书
2014年幼儿园老师工作总结
2014/12/05 职场文书
2015社区六五普法工作总结
2015/04/21 职场文书
python 模块重载的五种方法
2021/04/24 Python