SpringMVC + Ajax + Json 表单提交

上一次我们使用SpringMVC实现了一个表单提交应用,我们的表单长成这个样子:


图1

如果你在线填写过诸如"XXX市XXX职位申请"的话,那么你就会知道网页上需要的数据有多少,上三代都要被查,毕竟这是一个数据时代嘛。现在假设今晚就是申请表填写的deadline,但你发现你家的网不太好,刷新一次网页需要一分钟,这时候你填好了所有数据,点提交按钮,一分钟之后,因为时间匆忙,网页告诉你:密码格式不多,好,改一下,再次提交,地址格式不对。。。再来一分钟,邮箱不小心写错了。。。此处省略一万次提交。。。。

这时候你就像,我去,能不能实时反馈啊?

不知道你什么时候开始使用的百度,有没有发现从什么时候开始,搜索框可以试试动态根据你的输入展示搜索结果,以前可是没有的,那这个是怎么实现的呢?


图2

不错,这个就是Ajax,AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。这是Ajax的官方解释,其实它的工作机制是这样的:


图3

js实时处理你在网页上的动作,一旦触发,就将需要的数据发送到后台进行处理,后台处理之后实时反馈到网页上。

那么前台和后台数据交互的载体是什么呢?不再是xml文件,而是json数据。

现在我们来分别看看前台和后台是怎么工作的。

先看看前台部分:


图4

对应的代码:


图5

这里给登录按钮一个id,方便引用,因为我们希望在点击登录之后在后台验证或是创建用户。

那么这个点按钮的动作怎么触发呢?


图6

$(document).ready(function()这句话让页面stand by,随时准备响应网页上的动作。

$("#login").click(function()这里引用上面说的button id,给这个动作加了一个click动作,相当于onclick属性,然后用$.ajax表示这是一个ajax,我们来看看里面的主体都是些啥:

url:"test/testJSON.do",表明这个动作的响应url(controller里设置的RequestMapping)

type:"POST",(提交模式)

dataType:"json",(数据格式)

contentType:"application/json;charset=UTF-8",(内容格式)

data:JSON.stringify({(构造json格式的数据)

userName:$("#userName").val(),

userPassword:$("#userPassword").val()

})

图6后面的部分是成功和失败的提示。

紧接着你肯定要问,后台怎么接受数据的?我们来看看:


图7


图8

可以看到,前台传送的json数据的userName:$("#userName").val(),key值(userName)必须和User里定义的一样,这样后台就能通过@ResponseBody的到转换后的User对象,就能拿到一个完整的User对象,之后的操作就和上一篇文章里一样了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,056评论 5 474
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,842评论 2 378
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,938评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,296评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,292评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,413评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,824评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,493评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,686评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,502评论 2 318
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,553评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,281评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,820评论 3 305
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,873评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,109评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,699评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,257评论 2 341

推荐阅读更多精彩内容

  • AJAX 原生js操作ajax 1.创建XMLHttpRequest对象 var xhr = new XMLHtt...
    碧玉含香阅读 3,166评论 0 7
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,573评论 18 139
  • 大家好,我是IT修真院深圳分院第3期的学员,一枚正直纯洁善良的前端程序员,今天给大家分享一下,修真院官网前端工程师...
    大大头大阅读 7,500评论 1 72
  • 第一章 入门 基本功能:访问和操作 dom 元素,控制页面样式,对页面的事件处理,与ajax完美结合,有丰富的插件...
    X_Arts阅读 1,023评论 0 2
  • 又到过年了,每年这个时候,总会有三五个好友聚一聚,吃吃酒,聊聊天,话一把离愁,道一句家常,好不自在。可是不知道什...
    AMy119阅读 195评论 1 2