以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>Bitableoption>
- option>Kickableoption>
- 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=="
- }
- ]
- }

Microdatainhtml5enhancesseoanduserexperienceByByBybyBystructuredDatatoSearchEngines.1)useIteMscope,itemType,anditempropattributestomarkupcontentlikeSoreRoductSssSssSoRorevents.2)

html5introducesnewinputtypesthatenhanceserexperience,简化开发和iMproveAccessibility.1)自动validatesemailformat.2)优化优化,优化OmportizeSmizesemizesemizesemizesemizesemizeSmobobileWithAnumericKeyPad.3)和SimimplifyDtimePutputientiputiNputiNputits。

H5是HTML5,是HTML的第五个版本。HTML5提升了网页的表现力和交互性,引入了语义化标签、多媒体支持、离线存储和Canvas绘图等新特性,推动了Web技术的发展。

无障碍访问和网络标准遵循对网站至关重要。1)无障碍访问确保所有用户都能平等访问网站,2)网络标准遵循提高网站的可访问性和一致性,3)实现无障碍访问需使用语义化HTML、键盘导航、颜色对比度和替代文本,4)遵循这些原则不仅是道德和法律要求,还能扩大用户群体。

HTML中的H5标签是第五级标题,用于标记较小的标题或子标题。1)H5标签帮助细化内容层次,提升可读性和SEO。2)结合CSS可定制样式,增强视觉效果。3)合理使用H5标签,避免滥用,确保内容结构逻辑性。

HTML5构建网站的方法包括:1.使用语义化标签定义网页结构,如、、等;2.嵌入多媒体内容,使用和标签;3.应用表单验证和本地存储等高级功能。通过这些步骤,你可以创建一个结构清晰、功能丰富的现代网页。

通过合理的H5代码结构可以让页面在众多内容中脱颖而出。1)使用语义化标签如、、等组织内容,使结构清晰。2)通过CSS布局如Flexbox或Grid控制页面在不同设备上的呈现效果。3)实现响应式设计,确保页面在不同屏幕尺寸上自适应。

HTML5(H5)与旧版本HTML的主要区别包括:1)H5引入了语义化标签,2)支持多媒体内容,3)提供离线存储功能。H5通过新标签和API增强了网页的功能和表现力,如和标签,提高了用户体验和SEO效果,但需注意兼容性问题。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

Dreamweaver Mac版
视觉化网页开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

WebStorm Mac版
好用的JavaScript开发工具