`

screen widget 框架页面生成原理初探

 
阅读更多

v:  screen widget 本质是基于freemarker 的。 目前screen类型的view基本都是MacroScreenViewHandler.java 负责处理的。

 

 

v:MacroScreenViewHandler.java  render 方法中首先通过配置文件加载了三个类库。如下

 

[java] view plaincopy
 
  1. ScreenStringRenderer screenStringRenderer = new MacroScreenRenderer(UtilProperties.getPropertyValue("widget", getName() + ".name"), UtilProperties.getPropertyValue("widget", getName() + ".screenrenderer"));  
  2. FormStringRenderer formStringRenderer = new MacroFormRenderer(UtilProperties.getPropertyValue("widget", getName() + ".formrenderer"), request, response);  
  3. TreeStringRenderer treeStringRenderer = new MacroTreeRenderer(UtilProperties.getPropertyValue("widget", getName() + ".treerenderer"), writer);  



 

 

v:正式render 页面前后,利用freemarker 编译了两个宏指令

 

 

[java] view plaincopy
 
  1. screenStringRenderer.renderScreenBegin(writer, screens.getContext());  
  2.           screens.render(page);  
  3.           screenStringRenderer.renderScreenEnd(writer, screens.getContext());  

 

[java] view plaincopy
 
  1. public void renderScreenBegin(Appendable writer, Map<String, Object> context) throws IOException {  
  2.        executeMacro(writer, "renderScreenBegin"null);  
  3.    }  
  4.   
  5.    public void renderScreenEnd(Appendable writer, Map<String, Object> context) throws IOException {  
  6.        executeMacro(writer, "renderScreenEnd"null);  
  7.    }  

 

宏指令定义为

 

[html] view plaincopy
 
  1. <#macro renderScreenBegin>  
  2. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  
  3. </#macro>  
  4.   
  5. <#macro renderScreenEnd>  
  6. </#macro>  



 

v:screen widget 大概处理过程。获取screnn 第一个section ,解析处理action(预处理所需数据)condition,根据condition结果决定处理子widget是widget还是fail-widget 。子widget的处理过程和上层widget类似。如此深入。具体的没有嵌套的screen widget 可以使用上述freemarker 类库来编译成html。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics