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

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

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

    asdtiang的博客 感謝blogjava提供的博客交流平臺

    grails ajax分頁標簽實現

    Posted on 2010-11-26 14:20 asdtiang 閱讀(1210) 評論(0)  編輯  收藏 所屬分類: grails study

    一、設計目標
    1、采用ajax實現
    2、要多少條數據,取多少條,不從數據庫中一次性全部取出
    3、實現指定頁面跳轉
    4、用戶可以指定選擇每頁顯示幾條數據
    5、按那個字段排序
    6、最好不要占用session
    二、如何實現
    2、傳入參數:顯示頁碼,共有多少條數據,每頁顯示幾條數據,返回的頁面
           可選按那個字段排序

            if(!params.total){
                params.total=TestAjaxPage.count()///這個必須要,ajax請求時就不用在count總數了
            }
            params.view=params.view==null?"list":params.view
            params.max = Math.min(params.max ? params.max as int : 2, 100)
            params.linkTotal = Math.min(params.linkTotal ? params.linkTotal as int : 2, 100)
            params.offset = Math.min(params.offset ? params.offset as int : 0, 100)
            params.sort=params.sort==null?"dateCreated":params.sort
            params.order=params.order==null?"desc":params.order
    截個圖:

    talib code
    import org.springframework.web.servlet.support.RequestContextUtils as RCU;
    import org.codehaus.groovy.grails.commons.ConfigurationHolder
    class AjaxPageTagLib {
        def paginateAjax
    ={attrs ->
            def writer 
    = out
            params.offset 
    = Math.min(params.offset ? params.offset as int : 0100)
            params.sort
    =params.sort==null?"dateCreated":params.sort
            params.order
    =params.order==null?"desc":params.order
            def messageSource 
    = grailsAttributes.getApplicationContext().getBean("messageSource")
            def locale 
    = RCU.getLocale(request)        
            def total 
    = attrs.total.toInteger()
            def offset 
    = params.offset?.toInteger()
            def max 
    = params.max?.toInteger()
            
    int pageSize=Math.round(Math.ceil(total / max))    
            def path
    =request.getContextPath()    
            def pageNow
    =offset/max+1
            def selectMax
    =attrs.selectMax?.toInteger()
            
    if(!selectMax){
                selectMax
    =20
            }
            selectMax
    =selectMax>total?total:selectMax
            
    ////js輸出
            writer<<"""
             <div id="ajaxPage">
            
    """
            /////顯示首頁和上頁
            def firstText=messageSource.getMessage('paginate.first'null, messageSource.getMessage('default.paginate.first'null'First', locale), locale)
            def prevText
    =messageSource.getMessage('paginate.prev'null, messageSource.getMessage('default.paginate.prev'null'Prev', locale), locale)
            def nextText
    =messageSource.getMessage('paginate.next'null, messageSource.getMessage('default.paginate.next'null'Next', locale), locale)
            def lastText
    =messageSource.getMessage('paginate.last'null, messageSource.getMessage('default.paginate.last'null'Last', locale), locale)
            
            
    if(offset!=0){
                def firstUrl
    ="""offset=0&max=${params.max}&sort=${params.sort}&order=${params.order}&total=${total}"""
                writer
    <<"""
                <span id="firstShow" title="${firstText}" onclick="new Ajax.Updater('${attrs.update}',
            '${path}/${params.controller}/${params.action}',{asynchronous:true,evalScripts:true,parameters:'${firstUrl}'});
            
    return false;" >
                [${firstText}]
                
    </span>
                
    """
                int prev=offset-max
                def prevUrl
    ="""offset=${prev}&max=${params.max}&sort=${params.sort}&order=${params.order}&total=${total}"""
                writer
    <<"""
                    <span id="preShow" title="${prevText}" onclick="new Ajax.Updater('${attrs.update}',
                '${path}/${params.controller}/${params.action}',{asynchronous:true,evalScripts:true,parameters:'${prevUrl}'});
                
    return false;" >
                    [${prevText}]
                    
    </span>
                    
    """
            }
            
    else{
                writer
    <<"""<span id="firstNoShow" title="${firstText}">
                          [${firstText}]
                          
    </span>
                    
    """
                writer<<"""<span id="preNoShow" title="${prevText}">
                        [${prevText}]
                        
    </span>
                        
    """
            }
            
    ////數據信息輸出
            writer<<"""<span id="ajaxPageInfo">當前${pageNow}/${pageSize}頁(共${total})</span>"""
            
            
    //下一頁和末頁輸出,
            if(offset!=max*(pageSize-1)){
                
    int next1=offset+max
                def nextUrl
    ="""offset=${next1}&max=${params.max}&sort=${params.sort}&order=${params.order}&total=${total}"""
                
                writer
    <<"""
                    <span id="nextShow"   title="${nextText}" onclick="new Ajax.Updater('${attrs.update}',
                '${path}/${params.controller}/${params.action}',{asynchronous:true,evalScripts:true,parameters:'${nextUrl}'});
                
    return false;" >
                    [${nextText}]
                    
    </span>
                    
    """
                int last=max*(pageSize-1)
                def lastUrl
    ="""offset=${last}&max=${params.max}&sort=${params.sort}&order=${params.order}&total=${total}"""
                writer
    <<"""
                    <span id="lastShow" title="${lastText}" onclick="new Ajax.Updater('${attrs.update}',
                '${path}/${params.controller}/${params.action}',{asynchronous:true,evalScripts:true,parameters:'${lastUrl}'});
                
    return false;" >
                    [${lastText}]
                    
    </span>
                    
    """
            }
            
    else{
                writer
    <<"""<span id="nextNoShow" title="${nextText}">
                    [${nextText}]
                    
    </span>
                    
    """
                writer<<"""<span id="lastNoShow" title="${lastText}">
                    [${lastText}]
                    
    </span>
                    
    """
            }
            
    ///到指定頁連接輸出
            def selectUrl="&max=${params.max}&sort=${params.sort}&order=${params.order}&total=${total}"
            writer
    <<"""
            <span id="ajaxSelectText">轉到<select id="ajaxSelect" onchange="myUpdate('${attrs.update}','${path}/${params.controller}/${params.action}'
            ,'${selectUrl}','${max}')">
            
            
    """
            for(int j=1;j<=pageSize;j++){
                
    if(pageNow!=j){
                    writer
    <<"""  <option value ="${j}">${j}/${pageSize}</option>           """
                }
                
    else{
                    writer
    <<"""  <option value ="${j}"  selected="selected">${j}/${pageSize}</option>           """
                }
            }
            writer
    <<"</select>頁</span>"
            
            
    ////每頁顯示幾條數據
            def maxUrl="&offset=0&sort=${params.sort}&order=${params.order}&total=${total}"
            writer
    <<"""
                 <span id="ajaxMaxText"> 每頁顯示</span><select id="ajaxMax" onchange="myUpdate2('${attrs.update}','${path}/${params.controller}/${params.action}'
                ,'${maxUrl}')">
                """
            for(int j=1;j<=selectMax;j++){
                
    if(max!=j){
                    writer
    <<"""<option value ="${j}">${j}</option>"""
                }
                
    else{
                    writer
    <<"""<option value ="${j}"  selected="selected">${j}</option>"""
                }
            }
            writer
    <<"</select> </div>"
        }
    }

    example code

            if(!params.total){
                params.total
    =CompanyFinance.count()////注意total參數
            }
            def hql
    ="select id,title,dateCreated from CompanyFinance "
            params.view
    =params.view==null?"list":params.view
            params.max 
    = Math.min(params.max ? params.max as int : 2100)
            params.linkTotal 
    = Math.min(params.linkTotal ? params.linkTotal as int : 2100)
            params.offset 
    = Math.min(params.offset ? params.offset as int : 0100)
            params.sort
    =params.sort==null?"dateCreated":params.sort
            params.order
    =params.order==null?"desc":params.order
            params.selectMax
    ="true"///暫時沒用
            def results 
    = sessionFactory.currentSession.createQuery(hql+" order by ${params.sort} ${params.order}")
               .setCacheable(
    false)
               .setReadOnly(
    true)
               .setFirstResult(params.offset)
               .setMaxResults(params.max)
               .list()
        
            render view:params.view,model:[pageAjaxList:results,paginateAjaxTotal:params.total]
    <g:paginateAjax total="${paginateAjaxTotal}" update="update1"
        selectMax="20" />
    對了,還有js,css
    function myUpdate(update1, url1, parameters1, max) {
        
    var selectValue = document.getElementById("ajaxSelect").value
        
    var offset = max * (selectValue - 1)
        
    var newParams = "offset=" + offset + parameters1
        
    new Ajax.Updater(update1, url1, {
            asynchronous : 
    true,
            evalScripts : 
    true,
            parameters : newParams
        });
        
    return false;
    }
    function myUpdate2(update1, url1, parameters1) {
        
    var max = document.getElementById("ajaxMax").value
        
    var newParams = "max=" + max + parameters1
        
    new Ajax.Updater(update1, url1, {
            asynchronous : 
    true,
            evalScripts : 
    true,
            parameters : newParams
        });
        
    return false;
    }

    css:(css水平有限啊),table的css最好自己寫,如果 用默認的main.css會報錯

    @CHARSET "UTF-8";
    #firstShow
    {
      color
    :#0000cc;
      cursor
    :hand;
      cursor
    :pointer;
    }

    #preShow
    {
      color
    :#0000cc;
      cursor
    :hand;
      cursor
    :pointer;
    }
    #ajaxPageInfo
    {
      color
    :#000000;
    }

    #nextShow
    {
      color
    :#0000cc;
      cursor
    :hand;
      cursor
    :pointer;
    }
    #lastShow
    {
      color
    :#0000cc;
      cursor
    :hand;
      cursor
    :pointer;
    }


    #ajaxSelectText
    {
       color
    :#000000;
    }

    #ajaxMaxText
    {
       color
    :#000000;
    }
    #firstNoShow
    {
    }

    #preNoShow
    {

    }

    #nextNoShow
    {
    }

    #lastNoShow
    {
    }
    grails 1.1
    grails 1.3.5下測試通過
    最后頁面上應該以下幾句
     <g:javascript library="prototype" />
     <script type="text/javascript" src="${resource(dir: 'js', file: 'ajaxPage.js')}"></script>
     <link rel="stylesheet" href="${resource(dir:'css',file:'ajaxPage.css')}" />
    要源碼可以下載:
    hg clone https://asdtiang@bitbucket.org/asdtiang/mygrailsstudy
    hg: mercurial 一個分布式源碼管理工具,最近喜歡用這個




    天蒼蒼,野茫茫,風吹草底見牛羊

    posts - 80, comments - 24, trackbacks - 0, articles - 32

    Copyright © asdtiang

    asdtiang的博客 PaidMailz
    點擊廣告網賺A(每天4個廣告,每個0.0025美元,一個搜索廣告0.03美元)
    主站蜘蛛池模板: 久久99亚洲网美利坚合众国| 香蕉国产在线观看免费| 亚洲欧洲日产国码久在线观看| 老司机午夜免费视频| 无码精品一区二区三区免费视频| 亚洲一区精品无码| 成全在线观看免费观看大全 | 亚洲日韩精品一区二区三区无码| 免费无码AV一区二区| 成人免费大片免费观看网站| 国产成人精品高清免费| 亚洲精品亚洲人成在线| 日韩电影免费在线观看网站| 亚洲国产成人一区二区三区| 日韩免费视频一区二区| 免费一级大黄特色大片| 亚欧洲精品在线视频免费观看| 亚洲区小说区激情区图片区| 无人在线观看免费高清| 亚洲xxxx18| 亚洲AV无码乱码精品国产| 免费在线黄色电影| 亚洲人成网站看在线播放| 国产在线19禁免费观看| 中文字幕a∨在线乱码免费看| 亚洲视频在线观看| 成人免费看吃奶视频网站| 亚洲AV成人无码久久精品老人| 男人j进女人p免费视频| 亚洲国产精品国自产电影| 国产情侣激情在线视频免费看| 嫩草影院在线免费观看| 久久亚洲AV成人出白浆无码国产| 国产精品入口麻豆免费观看| 含羞草国产亚洲精品岁国产精品 | 91热成人精品国产免费| 亚洲AV综合永久无码精品天堂| 国产自偷亚洲精品页65页| 亚洲欧洲专线一区| 国精无码欧精品亚洲一区 | 四虎永久在线精品免费影视|