在开发过程中,数据传输是一个重要运行步骤,前台要向后台发送数据到Controller进行处理,后台也要想客户端返回页面或者数据。后台返回数据一般有三种方法:Model,ModelMap,ModelAndView。
1.Model
Model是一个接口,它的实现类为ExtendedModelMap,继承ModelMap类
public class ExtendedModelMap extends ModelMap implements Model
- 1
ModelMap继承LinkedHashMap
public class ModelMap extends LinkedHashMap<String,Object>
- 1
ModelAndView指模型和视图的集合,既包含模型 又包含视图。
注:前两种spring框架自动创建实例并作为controller的参数,在控制层函数注可直接作为参数写入。ModelAndView的实例需要开发者自己手动创建的,这也是和ModelMap主要不同点之一。
一:ModelAndView
ModelAndView是spring mvc中controller(控制器层)返回数据的一种方式,他包含Model和View。Controller将ModelAndView Return到DispacherServlet,读取View内容,通过Spring.xml中配置的ViewResolver进行解析,得到相应的jsp页面,并将Model参数带给View进行处理,最后返回jsp到客户端。
整体上看,通过一次请求,调用service层获得相应参数数据Model,并将参数带到一个页面,返回由参数处理过的页面,实现了和转发相同的效果。
此种方法一般用于返回固定页面和参数Model,model可以根据判断选择不同。
ModelAndView对象使用:
1.view的设置
1.ModelAndView mav = new ModelAndView("share");
2.mav.setViewName(String viewName);
new ModelAndView("share");
2.mav.setViewName(String viewName);
2.Model的设置
1.ModelAndView(View view, String modelName, Object modelObject);
2.mav.addObject(String ObjectName , Object ModelObject);
String modelName, Object modelObject);
2.mav.addObject(String ObjectName , Object ModelObject);
分层代码实现
1.Controller
public ModelAndView fun(){
......
return mav;
}
ModelAndView fun(){
......
return mav;
}
2.jsp
jsp文件中${requestScope.replayName}的形式来接收你在 mav.addObject("replayName", liveInfo.getReplayName()); 中设置的参数。
实例
1.Controller
<span style="color:#666666">public ModelAndView handle(HttpServletRequest arg0, HttpServletResponse arg1) throws Exception {
ModelAndView modelAndView = new ModelAndView("index");
modelAndView.addObject("List", service.getObjList());
return modelAndView;
} </span>
2.jsp
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<html>
<body>
<h1>List</h1>
<c:forEach items="${List}" var="obj">
${obj.name}
<br />
</c:forEach>
</body>
<html>
<html>
<body>
<h1>List</h1>
<c:forEach items="${List}" var="obj">
${obj.name}
<br />
</c:forEach>
</body>
<html>
二:ModelMap
1.返回参数数据
Controller
public ModelMap fun(ModelMap mm,...){
......
return mm;
}
ModelMap fun(ModelMap mm,...){
......
return mm;
}
jsp
$.ajax({
url:url,type:"post",
dataType:"json",
data:"...",
success:function(data){
$.massage.alert("info",data.info);
}
});
2.返回有参数处理的页面
......
modelmap.addAttribute(String modelname,Object ModelObject);
return "index";
}
modelmap.addAttribute(String modelname,Object ModelObject);
return "index";
}