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

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

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

    隨筆-348  評論-598  文章-0  trackbacks-0
    這個方法不是太完美,但可以解決JSF的DataTable和SelectOneRadio搭配問題。每條記錄每一行一個radio進行單選,只會選中一條。
    首先,在頁面中datatable的column中加入
                                                <h:selectOneRadio id="xx" value="#{entrance.test}">
                                                    
    <f:selectItem itemValue="#{obj.corpOutInfo.coiId}" itemLabel="#{obj.corpOutInfo.corpName}"/>
                                                
    </h:selectOneRadio>
    然后加入一段jquery的代碼用于在用戶切換選擇的時候,先將所有radio的checked狀態都置為false。
    <script type="text/javascript">
            jQuery.noConflict();
    //與JSF搭配需要這句話,不然會有沖突
            jQuery(document).ready(function() {

                jQuery(
    ":radio").click(function(){
                    update(
    this);

                 }
    );
            }
    );
            
    </script>
            
    <script type="text/javascript">
            
    function update(currentRadio)
            
    {

                
    var parentTables = jQuery(currentRadio).parents("table"); 
                
    var parentTable = parentTables[0];    

                
    var childDivs = jQuery(parentTable).next("div");        
                
    var childDiv = childDivs[0];        

                jQuery(childDiv).contents().find(
    ":radio").each(function() {
                    
    this.checked = false;
                }
    );
                
                currentRadio.checked 
    = true;
            }


            
    </script>

    后臺綁定一個屬性,但這個屬性的set方法會被調用多次,但只有一次是有值的,所以用戶選擇了哪一行也好獲得。
        private String test;
        
        
    public String getTest() {
            
    return test;
        }


        
    public void setTest(String test) {
            System.out.println(
    "=========================" + test);
        }


        
    問題算是解決了,實現很簡單,但并不太完美。因為后臺的那個set方法會觸發很多次,次數跟當前的radio數量一致,雖然不怎么影響性能,但用著總覺得不爽,后面再完善下。


    ---------------------------------------------------------
    專注移動開發

    Android, Windows Mobile, iPhone, J2ME, BlackBerry, Symbian
    posted on 2009-01-11 16:36 TiGERTiAN 閱讀(5452) 評論(5)  編輯  收藏 所屬分類: JavaJSF

    評論:
    # re: JSF中DataTable和SelectOneRadio搭配,每條記錄每一行一個radio進行單選的解決辦法 2009-01-12 12:39 | 千里冰封
    直接用h:outputText畫出HTML語句,這樣豈不是更好,然后在后臺從parameter里面去取這個單選的參數,應該也是一種辦法,呵呵  回復  更多評論
      
    # re: JSF中DataTable和SelectOneRadio搭配,每條記錄每一行一個radio進行單選的解決辦法[未登錄] 2009-01-12 21:38 | tigertian
    @千里冰封
    有個問題,就是你這個方法只能在jsf 1.2中使用,貌似1.1中沒有escape屬性,所以默認escape為true,在output里面畫不出來,會被Html Encode掉,如果單獨使用<input type="radio">控件,會發現jsf 1.1中的datatable無法把這個純html控件包含進來。而我目前碰到的應用環境正是jsf 1.1,所以我也想找到一個更好的辦法,大家討論討論哈。  回復  更多評論
      
    # re: JSF中DataTable和SelectOneRadio搭配,每條記錄每一行一個radio進行單選的解決辦法 2009-01-13 08:48 | TiGERTiAN
    @千里冰封
    今天測試了一下,1.1版本的outputText也有escape屬性,但我忘記是哪個控件跟1.2不一樣沒有escape屬性的,有了之后,就可以畫出來了。  回復  更多評論
      
    # re: JSF中DataTable和SelectOneRadio搭配,每條記錄每一行一個radio進行單選的解決辦法 2009-12-27 21:28 | frankie
    # re: JSF中DataTable和SelectOneRadio搭配,每條記錄每一行一個radio進行單選的解決辦法 2009-12-27 22:17 | TiGERTiAN
    @frankie
    謝謝哈,不過我用的是sun的實現。  回復  更多評論
      
    主站蜘蛛池模板: 亚洲精品无码人妻无码| 亚洲国产精品久久久久婷婷老年| 亚洲午夜电影一区二区三区| 99视频在线免费| 亚洲人成电影在线天堂| 99在线观看免费视频| 亚洲网址在线观看你懂的| 亚洲免费观看视频| 亚洲综合精品一二三区在线| 日韩内射激情视频在线播放免费| 久久青青草原亚洲av无码app | 亚洲综合网美国十次| 7m凹凸精品分类大全免费| 亚洲电影唐人社一区二区| h视频在线观看免费网站| 国产成人精品日本亚洲网址 | 亚洲不卡无码av中文字幕| 九九九精品视频免费| 亚洲乱码日产一区三区| 三年片在线观看免费大全电影| 亚洲视频在线不卡| 无码专区永久免费AV网站| 亚洲国产成人久久综合| 国产成人精品久久亚洲高清不卡 | 中国一级毛片免费看视频| 亚洲第一网站免费视频| 日本不卡视频免费| aa在线免费观看| 亚洲国语在线视频手机在线| 免费国产在线观看老王影院| 国产线视频精品免费观看视频| 亚洲精品自拍视频| 国产精品冒白浆免费视频| 成人性生交大片免费看好| 天天爽亚洲中文字幕| 亚洲A∨精品一区二区三区| 久草免费福利资源站| 亚洲精品中文字幕| 亚洲国产一二三精品无码| 成年美女黄网站18禁免费| 久久九九久精品国产免费直播|