<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    爪哇一角

    共同探討STRUTS#HIBERNATE#SPRING#EJB等技術
    posts - 3, comments - 6, trackbacks - 0, articles - 99
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    十二 自定義Renderer

    Posted on 2009-01-20 14:50 非洲小白臉 閱讀(275) 評論(0)  編輯  收藏 所屬分類: JSF

    上面的例子,表現層的編碼,解碼工作都是Component自己完成的,但是這樣的話,自定義Component的重用行就很差了。

    所以這里要自定義一個Renderer來做編碼,解碼工作。要自定義一個Renderer,需要繼承javax.faces.render.Renderer

    package test;

    import java.io.IOException;

    import java.util.Map;

    import javax.faces.component.EditableValueHolder;

    import javax.faces.component.UIComponent;

    import javax.faces.component.UIInput;

    import javax.faces.context.FacesContext;

    import javax.faces.context.ResponseWriter;

    import javax.faces.render.Renderer;

    public class TextCmdRenderer extends Renderer {

    private static final String TEXT = ".text";

        private static final String CMD = ".cmd";

        //編碼

        public void encodeBegin(FacesContext context,

                UIComponent component) throws IOException {

             ResponseWriter writer = context.getResponseWriter();

             String clientId = component.getClientId(context);

           

             encodeTextField(component, writer, clientId);

             encodeCommand(component, writer, clientId);

          }

        //解碼

          public void decode(FacesContext context,

                                    UIComponent component) {

             Map reqParaMap = context.getExternalContext().

                                        getRequestParameterMap();

             String clientId = component.getClientId(context);

           

             String submittedValue =

                       (String) reqParaMap.get(clientId + TEXT);

             ((EditableValueHolder) component).setSubmittedValue(

                                                  submittedValue);

             ((EditableValueHolder) component).setValid(true);

          }

          private void encodeTextField(UIComponent component,

                          ResponseWriter writer, String clientId)

                                           throws IOException {

             writer.startElement("input", component);

             writer.writeAttribute("name", clientId + TEXT, null);

           

             Object value = ((UIInput) component).getValue();

             if(value != null) {

                 writer.writeAttribute("value",

                              value.toString(), null);

             }

             String size =

                  (String) component.getAttributes().get("size");

             if(size != null) {

                 writer.writeAttribute("size", size, null); 

             }

             writer.endElement("input");

          }

          private void encodeCommand(UIComponent component,

                             ResponseWriter writer,

                             String clientId) throws IOException {

             writer.startElement("input", component);

             writer.writeAttribute("type", "submit", null);

             writer.writeAttribute("name", clientId + CMD, null);

             writer.writeAttribute("value", "submit", null);

             writer.endElement("input");

          }

    }

    這個Renderer和之前Component的編碼解碼過程類似,只是方法上多了一個UIComponent參數,用來表示對應的Component

    faces-config.xml中配置定義的Renderer

    <!-- 自定義Renderer -->

           <render-kit>

             <renderer>

                 <component-family>

                     javax.faces.Input

                 </component-family>

                 <renderer-type>

                     test.TextCmd

                 </renderer-type>

                 <renderer-class>

                     test.TextCmdRenderer

                 </renderer-class>

             </renderer>

         </render-kit>

    定義好了之后,只需要把上面自定義的那個Tag文件稍微修改一下就可以了:

    public String getComponentType() {

            //return "test.TextWithCmd";

            return "javax.faces.Input";

        }

        public String getRendererType() {

            //return null;

           return "test.TextCmd";

        }

     

    同樣的,你也可以在自定義的Component中設置使用的Renderer。修改上面自定義Component的構造函數就可以了。

     

    大家自己去試一下吧。具體程序參看示例程序。

     

    主站蜘蛛池模板: 久久青草免费91线频观看不卡| 亚洲精品人成电影网| 国产精品亚洲综合网站| 久久久久久久91精品免费观看| 久久国产亚洲高清观看| 久久久久久久岛国免费播放 | 久久亚洲sm情趣捆绑调教| 国产免费爽爽视频在线观看| 亚洲精品乱码久久久久久蜜桃 | 亚洲精品456人成在线| 美女被cao免费看在线看网站| 亚洲熟妇色自偷自拍另类| 亚洲香蕉免费有线视频| 亚洲一区二区久久| 日韩精品成人无码专区免费| 亚洲人妖女同在线播放| www.黄色免费网站| 亚洲精华国产精华精华液| 国产网站免费观看| 国产成人亚洲精品电影| 亚洲福利中文字幕在线网址| 国产免费A∨在线播放| 亚洲成AV人片在线观看ww| 无码专区AAAAAA免费视频| 91在线亚洲精品专区| 一二三四免费观看在线电影| 在线观看亚洲电影| 2048亚洲精品国产| 久久精品国产免费观看| 亚洲JIZZJIZZ妇女| 亚洲色欲久久久久综合网| 午夜精品射精入后重之免费观看| 亚洲一卡二卡三卡| 国产一区二区三区免费视频| a级毛片免费网站| 亚洲天堂福利视频| 亚洲成a人在线看天堂无码| 久久久久久影院久久久久免费精品国产小说 | 免费人成在线视频| 一区二区三区免费精品视频| 久久亚洲中文字幕精品有坂深雪 |