基于StringTemplate的视图
一 StringTemplate介绍
StringTemplate 是一个可以生成原代码,web页面,emails和其它任何需要有格式的文本输出的模板引擎。它目前支持三种语言:Java, c#, python.
许多应用在web中的模板引擎,不强制分离视图(view)与控制器(controller)。Mvc中已经强调业务逻辑模型与视图的分离,如果模型和视图分离的不彻底,那么就违背mvc结构了,所以个人觉得StringTemplate应用重点是强制MVC中的view 与 Controller的分离。
关于StringTemplate 分离控制器与视图的特性, 请参考RicCC 对mvc.templates的中文翻译 –在模板引擎中强制模型-视图严格分离(http://www.cnblogs.com/RicCC/archive/2007/06/03/769642.html)
关于StringTemplate 官方网站 www.stringtemplate.org (http://www.antlr.org/wiki/display/ST/StringTemplate+3.0+Documentation)
二 MVC结构简介
模型 - 模型用于管理应用程序域的行为和数据,并响应为获取其状态信息(通常来自视图)而发出的请求,还会响应更改状态的指令(通常来自控制器)。在分层结构中,业务逻辑是归于模型这里的。
视图 - 视图用于管理信息的显示。视图在B/S结构中,是web浏览器中的用户界面,它将数据显示出来供用户查看,提供表单等用来接受用户的键盘、鼠标事件并触发Http请求给控制器(Controller).
控制器 - 控制器用于解释用户的鼠标和键盘输入,以通知模型和/或视图进行相应的更改。用户在视图中触发的请求通常包括刷新页面,提取数据,添-删-改 数据等,控制器接收这些请求后,将对这些请求进行分发处理,它将指定命令调用模型对这些请求进行处理,并根据处理的结果通知视图进行更新。
三 StringTemplate应用
1.视图与模型的关系
视图是模型中的数据信息在用户端的显示,由于用户的需求,和浏览设备的差异,视图可以有多个版本。在B/S结构里面即浏览器里面的用户界面。
对于门户网站,用户界面通常根据季节或者某个活动,某个节日而变动,门户网站通常有自己的开发人员,他们对自己的网站需求方面应该是非常熟悉的。每当用户界面需要变动,需要改动或添加部分的业务逻辑以提供新的视图数据时,对于浏览器/用户来说,大多情况下只是在某一段时间里呈现一种视图界面。所以这种视图变换,即使视图,模型变动较大,也不会影响太大。这种视图变换,呈现出的是某一段时间里的视图和模型时一对一的关系,这种关系相对简单。
而对于基于web的产品来讲,视图与模型的关系就复杂了。
对于门户网站,虽然现在web2.0的网站增强了用户的交互性,但依旧还是用户适应门户开发团队开发出来的视图(用户界面)。而产品,就有客户需求是多样化的。对于产品来讲,模型(Model)就是产品的实质所在,这个是客户需求的根本;视图是产品的外包装,客户通常在确定功能需求后,需要定制视图。由于客户(通常是某一机构,某一运营商)他们所针对的消费群体的不同,或者老板的喜好不同,在视图定制上的差异通常很大。这时视图和模型呈现出的是一种一对多的关系,即 一个模型多种视图
这些视图差异通常表现在界面的布局上,数据的显示上,少部分的视图需要添加新的逻辑来呈现新的数据。
在产品定制视图(用户界面)的这种情况下,模型是基本不变的,视图是多样的变化的。
2.StringTemplate的作用
StringTemplate通过一套表达式语言和模板定义方式,为视图多样化的定义提供了简单的引擎。
StringTemplate将页面想像成一个模板,模板中有许多填充点,即如上图的 A,B,在向用户呈现视图时,先对这些数据填充点进行初始化,再发送给用户。一个网站由一套很多的这些可填充的模板组成。由于基本的业务逻辑模型不变,所以这些数据填充点几乎变化很少,变的只是视图界面的呈现组织上。
这样,多界面的实现就变得可能及简单。
3.StringTemplate的应用
当前在.NET下,出现了许多MVC的web框架,如MonoRail, Maverick。 MonoRail改变了Asp.net自带的后置代码的模型-视图分离的页面控制器MVC模式,采用自己的一套前端控制器(Front-Controller)MVC模式,它可以通过三种模板引擎来实现视图和控制器的分离。个人对MonoRail不熟悉,这里不多叙述。
在本次应用中,初步掌握了StringTemplate实现多视图界面的功能。由于StringTemplate采用ST文件模板及其自己的表达式来描述将要显示的可填充的模板文件,实现了视图与控制器的完全强制分离。它不可以使用asp.net下大量集成的服务器控件,于是表单的交互操作要回到传统的asp交互模式,也可以采用ajax 来实现交互。
应用示意图:
解释过程:
1. 首先浏览器(client)发送请求,这个请求可以是用户对页面的请求,或与表单进行交互操作的事件。
2. 控制器,接收请求,并选择合适的命令对请求进行处理,比如命令A,(这里不讨论是页面控制器还是前端控制器)
3. 命令A 解析http请求中的参数,并调用模型进行逻辑处理(添,删,改等等运算),处理完毕如果需要返回视图,则(1)解析View.xml文件,提取页面包含的模块信息,再根据这些模块信息加载模块。(2)加载模块时,同样解析View.xml文件,提取模块配置信息。模板加载完毕,再将处理结果绑定到数据填充点上
4. 处理完毕,将视图返回给浏览器。
注:上面是个人对这次应用StringTemplate实现多界面程序的粗略总结。由于个人知识浅薄,上面的文字不够清晰明了,希望各位多多指教,砸砖头
ps:
里面mvc及StringTemplate部分概念直接参照了网上搜索的资料,如果参照了您的,影响了您的利益,请指出,我将在第一时间删除。