<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的構造函數就可以了。

     

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

     

    主站蜘蛛池模板: 久久亚洲av无码精品浪潮| 久久久无码精品亚洲日韩蜜桃| 精品无码国产污污污免费| 亚洲AV成人潮喷综合网| 亚洲A∨无码一区二区三区| 久久国产福利免费| 波多野结衣免费在线| 无码专区一va亚洲v专区在线| 亚洲国产精品久久久久秋霞小| 久久免费动漫品精老司机| 免费午夜爽爽爽WWW视频十八禁| 亚洲日本在线观看| 国产亚洲精品91| 免费精品无码AV片在线观看| 亚洲Av无码乱码在线播放| 亚洲不卡1卡2卡三卡2021麻豆| 国产精品免费在线播放| 麻豆精品国产免费观看| 国产精品亚洲专一区二区三区| 又粗又大又硬又爽的免费视频| 一级毛片aaaaaa视频免费看| 免费无码成人AV片在线在线播放| 亚洲欧美国产精品专区久久| 亚色九九九全国免费视频| 亚洲男同帅GAY片在线观看| 国产亚洲午夜精品| 久久亚洲色一区二区三区| 99热这里只有精品免费播放| 精品亚洲AV无码一区二区三区| 国产精品四虎在线观看免费 | 亚洲国产一二三精品无码| 深夜免费在线视频| 国产中文字幕免费| 亚洲GV天堂无码男同在线观看| 亚洲成人国产精品| 18禁美女黄网站色大片免费观看| 久久精品国产亚洲沈樵| 国产在线观看免费视频软件| 九月丁香婷婷亚洲综合色| 国产一卡二卡四卡免费| 免费无码一区二区|