在这几者中,ModelAndView、ModelMap、Model是直接可以放在控制器方法的参数中的,在Spring MVC运行的时候,会自动初始化它们。
其中ModelMap和Model必须放在方法参数中才能完成初始化。
若放在参数中进行初始化,则不论是Model的参数还是ModelMap的参数,Spring MVC都会将其进行实例化为BindingAwareModelMap,因此Model的参数和ModelMap的参数之间是可以进行相互转换的。
ModelAndView既可以放在方法参数中完成初始化,也可以在方法中进行手动实例化,在实例化ModelAndView后,ModeAndView对象中model属性默认为空,当调用它增加数据后,才自动创建实例。
在SpringMVC中,可以通过实例化Model、Map或者ModelMap对象,并向其中放置数据(实则是放到了request请求域中),实现从后端向前端页面传递数据,这三者实现的功能是一样的,那么他们又有什么联系呢?
通过分析这三个类的的调用栈,可以发现,这三个类最终底层的调用都是
org.springframework.validation.support.BindingAwareModelMap
那么为什么Model、Map、ModelMap最终都是使用BindingAwareModelMap来实现参数的设置呢?
一、先来分析ModelMap,从源码中不难发现ModelMap的父类是LinkedHashMap
public class ModelMap extends LinkedHashMap<String, Object>
而LinkedHashMap是Map接口的实现类,那么ModelMap其实是Map接口的实现类。
public class LinkedHashMap<K,V>
extends HashMap<K,V>
implements Map<K,V>
二、再来看BindingAwareModelMap,通过对它的源码分析,我们发现它实际上是继承了ExtendedModelMap。
public class BindingAwareModelMap extends ExtendedModelMap
再对ExtendedModelMap的源码进行分析,发现它继承了ModelMap并实现了Model接口:
public class ExtendedModelMap extends ModelMap implements Model
由此不难看出,无论是使用Map还是Model或者是ModelMap设置数据,最终在运行时使用的对象都是BindingAwareModelMap。