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对象,之后的操作就和上一篇文章里一样了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

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