<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美元)
    主站蜘蛛池模板: 色播精品免费小视频| 可以免费观看的毛片| 69堂人成无码免费视频果冻传媒| 久久亚洲精品国产精品黑人| 久久国产精品免费一区二区三区| 亚洲精品456播放| 一级免费黄色大片| 在线观看亚洲精品国产| 99在线免费视频| 久久夜色精品国产噜噜亚洲AV| 日韩电影免费观看| 中文字幕亚洲免费无线观看日本| 亚洲成人激情在线| 免费国产在线视频| 国产成人无码a区在线观看视频免费| a毛片全部播放免费视频完整18| 亚洲伊人久久大香线蕉苏妲己| 日韩亚洲国产二区| 亚洲精品国产摄像头| 亚洲成a人片在线观看中文app| 2048亚洲精品国产| 国产精品免费观看久久| 毛片免费vip会员在线看| 亚洲精品视频专区| 又爽又高潮的BB视频免费看| 免费精品视频在线| 亚洲国产一区二区三区青草影视| 亚洲日韩看片无码电影| 亚洲精品国产字幕久久不卡| 日本视频免费在线| 亚洲AV伊人久久青青草原| av无码东京热亚洲男人的天堂| 久久99亚洲综合精品首页| 久久亚洲精品无码播放| 亚洲成a人片在线观看无码专区| 免费无码精品黄AV电影| 午夜免费不卡毛片完整版| a级大片免费观看| 最近2019免费中文字幕视频三| 思思re热免费精品视频66| 久久久无码精品亚洲日韩京东传媒|