SpringMVC响应Ajax请求(@Responsebody注解返回页面)

来源:互联网 发布:南京麦芽金服数据 编辑:程序博客网 时间:2024/05/18 23:56

项目需求描述:page1中的ajax请求Controller,Controller负责将service返回的数据填充到page2中,并将page2整个页面返回到page1中ajax的回调函数。
一句话表述:利用SpringMVC,以一个页面作为响应返回给ajax。

接下来,我们将介绍怎样将这样的需求实现到SpringMVC中,废话不多说,分步上代码。

1. Jquery ajax请求

对这部分不太熟悉的同学可以移步我的另一篇博客详解jQuery中ajax函数:$.get(),$.post(),$.ajax()。首先我们需要向Controller发送ajax请求。

function res(){    $.post('mine',{        qt:$('#mtext').attr('value')    },function(data) {        $('#queryresult').html(data);    });}

page1页面

<div id="queryresult"></div>

页面中具体实现的内容不进行赘述,各位客官根据自身项目情况进行脑补即可。

2. SpringMVC处理ajax请求

先介绍一个SpringMVC中的注释@Responsebody。使用@Responsebody标识的方法表示该方法的返回结果直接写入HTTP response body中,一般在异步获取数据时使用,在使用@RequestMapping后,返回值通常解析为跳转路径,加上@Responsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如异步获取json数据,加上@Responsebody后,会直接返回json数据。

import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.RequestMethod;import org.springframework.web.bind.annotation.ResponseBody;import org.springframework.web.servlet.ModelAndView;import javax.annotation.Resource;import java.io.IOException;import java.util.List;@Controllerpublic class DMController {    @Resource    private IDMService dmService;    @RequestMapping(value = "/mine",method = RequestMethod.POST)    public @ResponseBody ModelAndView textMine(String qt,ModelAndView m) throws IOException {        List<QueryResult> qrresults=dmService.getQueryResults(qt);//QueryResult是自定义的pojo        m.addObject("queryresults",qrresults);        m.setViewName("page2");        return m;    }}

利用ModelAndView将Service中的结果值传到page2页面,并将ModelAndView对象返回到ajax。

page2页面

<c:forEach items="${queryresults}" var="queryresults">    <div>        <p>${queryresults.resultTitle}</p>        <p>${queryresults.resultContent}</p>    </div></c:forEach>

至此,SpringMVC以页面响应Ajax请求的整个过程也结束,整个过程还需要各位客官仔细理解,然后结合自己的实际需求进行改进。项目中运用到的场景如下图。
springmvc响应ajax请求

参考:
http://www.aichengxu.com/view/38943

0 0
原创粉丝点击