浏览 1805 次
锁定老帖子 主题:扩展etmvc的视图
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2009-05-07
最后修改:2009-06-19
etmvc中的视图对应MVC中的view,每个Action方法的返回类型决定了视图输出的类型,内置的几种视图是: JspView TextView StringView JsonView FreeMarketView BinaryView 如果Action方法返回void则将使用VoidView,VoidView将使用同JspView一样的处理方式,可以简单认为就是JspView。
关于etmvc的详细资料,请访问www.etmvc.cn
视图的渲染由相应的renderer对象完成。比如JspView有相应的JspViewRenderer,通过在JspView中使用@ViewRendererClass注解关联起来。
扩展视图很容易,我们以扩展JavaScriptView为例说明一下: 1、编写视图,需要继承View @ViewRendererClass(JavaScriptViewRenderer.class) public class JavaScriptView extends View{ private String js; public JavaScriptView(String js){ this.js = js; } public String getJs() { return js; } public void setJs(String js) { this.js = js; } } 2、编写视图渲染类,需要继承AbstractViewRenderer public class JavaScriptViewRenderer extends AbstractViewRenderer<JavaScriptView>{ public void renderView(JavaScriptView view, ViewContext context) throws Exception{ PrintWriter out = context.getResponse().getWriter(); out.print("<script>"+view.getJs()+"</script>"); out.close(); } }
3、在视图类上应用注解,指定相应的渲染类
这样,自定义视图就完成了,可以在Action中使用了。 public class TestController extends ApplicationController{ public View index(){ JspView view = new JspView(); view.setAttribute("hello", "Hello,World,test index"); return view; } public View jstest(){ JavaScriptView view = new JavaScriptView("alert('abc');"); return view; } }
执行程序,打开浏览器,输入http://localhost:8080/test/test/jstest,可以看到显示'abc'的对话框。
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |