发现spring 3已经对ajax支持的很好了,前端可以只使用html+jquery,后端 
只使用spring再加上一种orm,两者之间用json交换数据就可以了,现在是放弃 
jsp,struts这些已经显得累赘的技术的时候了。 
出于这种想法,我做了个小试验,其中之所以选择jquery 1.3.2是因为jquery 
ui 1.8还不是稳定版,而稳定版1.7是基于jquery 1.3+的。

1. 先从前台提交数据开始,关键代码如下: 
Javascript代码 
function save() {   
    var elemUserinfo = $('#customerInfo');   
    var userinfo = elemUserinfo.serializeObject();   
    var jsonuserinfo = JSON.stringify(userinfo);   
       
    jQuery.ajax({   
        type : 'POST',   
        contentType : 'application/json',   
        url : 'customerInfo/new.do',    
        data : jsonuserinfo,   
        dataType : 'json',   
        success : function(data){   
            $('div#responseName').text(data.name);   
            $('div#responseAddr').text(data.addr);   
        },   
        error : failed   
    });   
}  
其中customerInfo是一个form的id,该form包含两个text input,name分别为name和addr, 
serializeObject是一个网上比较流行的将form数据组装成json对象的juery扩展,代码如下: 
Javascript代码 
$.fn.serializeObject = function() {   
    var o = {};   
    var a = this.serializeArray();   
    $.each(a, function() {   
        if (o[this.name]) {   
            if (!o[this.name].push) {   
                o[this.name] = [ o[this.name] ];   
            }   
            o[this.name].push(this.value || '');   
        } else {   
            o[this.name] = this.value || '';   
        }   
    });   
    return o;   
};  
将json对象转成String是用的json2(http://www.json.org/js.html)的JSON.stringify,提交 
是用的jquery的ajax功能,注意要把contentType设为'application/json',这是为了后台spring 
将其自动转化为vo对象用的。 
关于返回值后面再说。

2. 然后说说后台spring的接收。 
后台主要的代码如下: 
Java代码 
@Controller  
@RequestMapping("/customerInfo")   
public class CustomerInfoController {   
       
    @RequestMapping(value="/new", method = RequestMethod.POST)   
    @ResponseBody  
    public Customer newCustomer(@RequestBody Customer customer) {   
        customer.setName(customer.getName() + "经服务器修改");   
        customer.setAddr(customer.getAddr() + "经服务器修改");   
           
        return customer;   
    }   
}  
其中Controller,RequestMapping什么的就不多说了,简单的说就是前提交时指定的url( 
customerInfo/new.do)就被spring转到这里来处理了,其中web.xml中spring的设置如下: 
Xml代码 
<servlet>  
    <servlet-name>test</servlet-name>  
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
    <load-on-startup>1</load-on-startup>  
</servlet>  
  
<servlet-mapping>  
    <servlet-name>test</servlet-name>  
    <url-pattern>*.do</url-pattern>  
</servlet-mapping>  
注意处理申请的函数的参数直接就是Customer对象(Customer是一个具有属性name和addr的vo), 
而不是json字串,这里的关键是这样的,spring具有将数据转化后再交给controller的功能,spring 3 
新增了对json的处理能力,是基于Jackson JSON Processor(http://jackson.codehaus.org/)的, 
使用时要配置一下,在这个例子中默认的bean定义文件test-servlet.xml中这样写: 
Xml代码 
<bean  
    class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">  
    <property name="messageConverters">  
        <util:list id="beanList">  
            <ref bean="mappingJacksonHttpMessageConverter" />  
        </util:list>  
    </property>  
</bean>  
  
<bean id="mappingJacksonHttpMessageConverter"  
    class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter" />  
这样一来,spring在接收contentType为application/json的request时会自动将json字串间转换成期望 
的java对象,同样,发送response时,contentType被设为application/json,并且将java对象转为json 
字串。

3. 下面该说返回了 
上面已经说到,spring自动将response进行json化,所以处理函数直接返回vo对象就可以了。 
而在页面端,由于我们指定了dataType为json,所以jquery直接把接收到的json字串转成了javascript 
对象,我们可以直接使用data.name的写法取得数据了。

简单吧,这样一来,开发中,可以由设计人员在需求分析的基础上专心用html制作页面,之后交到前端 
开发人员手里,前端开发人员添加js代码,实现页面逻辑,后台人员专心于java,spring和orm,前后 
端交换json数据就可以了。

jquery(1.3.2)<--json-->spring(3.0)的更多相关文章

  1. Jquery跨域获得Json

    这两天用 Jquery 跨域取数据的时候,经常碰到 invalid label 这个错误,十分的郁闷,老是取不到服务器端发送回来的 json 值, 一般跨域用到的两个方法为:$.ajax 和$.get ...

  2. 通过Jquery中Ajax获取json文件数据

    1. JSON(JavaScript Object Notation): javaScript对象表示法: 是存储和交换文本信息的语法,比xml更小,更快,更易解析. 2. JSON基本书写格式 : ...

  3. jquery ajax调用返回json格式数据处理

    Ajax请求默认的都是异步的 如果想同步 async设置为false就可以(默认是true) var html = $.ajax({ url: "some.php", async: ...

  4. (转)springMVC框架下JQuery传递并解析Json数据

    springMVC框架下JQuery传递并解析Json数据 json作为一种轻量级的数据交换格式,在前后台数据交换中占据着非常重要的地位.Json的语法非常简单,采用的是键值对表示形式.JSON 可以 ...

  5. spring boot2.0(一 ) 基础环境搭建

    1.基础配置 开发环境:window jdk版本:1.8(spring boot2.0最低要求1.8) 开发工具:eclipse 构建方式:maven3 2.POM配置文件 <project x ...

  6. 通过JQuery的$.ajax()把 json 数据 post 给 PHP

    通过JQuery的$.ajax()把 json 数据 post 给 PHP时的几种情况: 无法在PHP中通过$_POST 以及 $_REQUEST 获取json数据,即 $json = $_POST[ ...

  7. Spring Boot2.0 整合 Kafka

    Kafka 概述 Apache Kafka 是一个分布式流处理平台,用于构建实时的数据管道和流式的应用.它可以让你发布和订阅流式的记录,可以储存流式的记录,并且有较好的容错性,可以在流式记录产生时就进 ...

  8. spring boot 2.0(一)权威发布spring boot2.0

    Spring Boot2.0.0.RELEASE正式发布,在发布Spring Boot2.0的时候还出现一个小插曲,将Spring Boot2.0同步到Maven仓库的时候出现了错误,然后Spring ...

  9. 【MVC model 验证失效 】【Unexpected token u in JSON at position 0】【jquery-plugin-validation】

    问题描述:mvc model 调用jquery-plugin-validation 实现 前台的数据验证,时报错 Unexpected token u in JSON at position 0 很讨 ...

  10. Spring Boot2.0之 监控管理

    Spring boot监控中心: 针对微服务的服务状态,服务器的内存变化(内存.线程.日志管理等)检测服务配置连接地址是否有用(有些懒加载的情况下,用的时候发现卧槽不能用)模拟访问,懒加载.统计有多少 ...

随机推荐

  1. IIS7下swfupload上传大文件出现404错误

    要求上传附件大小限制在2G,原本以为可以轻松搞定.在编译模式下可以上传大文件,可是在IIS7下(自己架的服务器),一上传大的文件就会出现 Http 404错误,偶尔有的文件还有IO. error错误. ...

  2. [Android开发系列]IT博客应用V1.3

    首先,感谢使用这款软件并给我意见的朋友们,有你们的意见,才有了这个版本. 其次,检索功能和分类筛选功能(如果是你提的意见,记得在下面mark哦,毕竟读代码你能发现,其实发意见这个就是用自己的邮箱给自己 ...

  3. ajax 返回数据 无法得到其属性的解决办法

    当我们用ajax无法 得到其属性.正常情况下是: <script type="text/javascript">        function useAjax(sen ...

  4. 20150301—ASP.NET的Repeater

    Repeater与GridView等数据列表一样,都是用来显示数据库的信息的,其中Repeater是最基本的列表形式,其用法也比较灵活. 一.Repeater的位置: 工具箱-数据-Repeater ...

  5. OpenGL-渲染管线的流程(有图有真相)

    视频教程请关注 http://edu.csdn.net/lecturer/lecturer_detail?lecturer_id=440 学习shader之前必须知道的事情,shader(着色语言)到 ...

  6. C# 将日期转换成中文格式

    没有什么难点,只是要小心,要考虑到月.日上 10 的说法,比如:10 不能直接转换成一〇,也不能像上 20 那样转换成一十〇,应该是十. 特点总结: 数字为 10 时,结果为十: 数字大于 10 时, ...

  7. OSX 上初步尝试 asp.net 5

    去年微软最令开源狗界振奋的消息就是 ASP.NET 的开放与开源这一消息了. 根据微软的介绍,与我之前的一些总结,可以看到 ASP.NET 以及 .NET 平台会有下面几个变化: 代码使用 Apach ...

  8. C++ 中的 const 详解

    作者:jostree 转载请注明出处 http://www.cnblogs.com/jostree/p/4235721.html 1.为什么使用 const int 而不使用 #define 在使用# ...

  9. 多线程更新已排序的Datagridview数据,造成数据错位

    多线程更新已排序的Datagridview数据,触发Datagridview的auto-sort时间,数据重新排序,造成后面更新数据的更新错误. 解决方法: 方法一.设置Datagridview的表头 ...

  10. 一个好用的PHP验证码类

    分享一个好用的php验证码类,包括调用示例. 说明: 如果不适用指定的字体,那么就用imagestring()函数,如果需要遇到指定的字体,就要用到imagettftext()函数.字体的位置在C盘下 ...