在多表存储同一对象相关信息时,如果要查询该对象的信息来自这多个表那么可以通过多表联合查询等等方案实现;但是,这种做法有一种缺点,每个表对应的model并不包含其他表中字段的定义,这样就使得多表联合查询的数据采用model类型的对象返回到前端变得比较困难或者说不方便。在开发中采用另外一种方式来获取数据,就显得很方便易用。这种方式的实现原理是实例化一个DAL层或者BLL层的类的对象,该对象可以调用类中的方法,然后通过PropertyBag.Add("变量名", 实例化的对象);的方式把这个对象返回到前端,在前端的模板中可以直接采用$变量名.方法的形式来调用想调用的方法,这样就解决了上面提到的困难。
代码示例:
控制器代码
DAL.PhotoSale PSale = new DAL.PhotoSale();
PropertyBag.Add("PhotoSale", PSale);
模板代码
<td>
#set($Status=${PhotoSale.GetPhotoSaleStatus($photo.PhotoID)})
#set($message="出售中")
#if($Status==-3||$Status==-2)
#set($message="待处理")
#elseif($Status==-1)
#set($message="审核中……")
#elseif($Status==0)
#set($message="审核未通过")
#end
<p>$message</p>
</td>