<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 非洲小白臉 閱讀(270) 評論(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的構造函數就可以了。

     

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

     

    主站蜘蛛池模板: 亚洲欧洲免费无码| 国产一精品一aⅴ一免费| 亚洲av片不卡无码久久| 免费一级毛片在线播放不收费| 国产一级高青免费| 亚洲精品国产精品国自产网站| 精品久久免费视频| 中国黄色免费网站| 亚洲xxxx视频| 亚洲AV人无码激艳猛片| 免费看少妇作爱视频| 亚洲视频在线免费观看| 国产精品亚洲а∨无码播放麻豆 | 国产99久久亚洲综合精品| 亚洲色精品vr一区二区三区 | 国产h视频在线观看网站免费| 国产精品亚洲专区无码牛牛| 亚洲精品国产成人片| 午夜无遮挡羞羞漫画免费| 久久精品电影免费动漫| 精品在线视频免费| 亚洲首页国产精品丝袜| 国产亚洲精品自在久久| 国产一级淫片a免费播放口之| 67194成手机免费观看| 久久久精品国产亚洲成人满18免费网站| 国产v亚洲v天堂a无| 亚洲AV无码成人专区片在线观看 | 成人国产精品免费视频| 亚洲成a人片在线观看天堂无码| 亚洲精品乱码久久久久久久久久久久 | 亚洲国产乱码最新视频| 亚洲AV成人片色在线观看| 亚洲第一视频在线观看免费| 毛片A级毛片免费播放| 最近2022中文字幕免费视频| 国产免费福利体检区久久| 国产天堂亚洲精品| 亚洲色大18成人网站WWW在线播放 亚洲色大成WWW亚洲女子 | 97在线观看永久免费视频| 色欲国产麻豆一精品一AV一免费|