LigerUI之Grid使用詳解(一)——顯示數據 --分頁


http://www.cnblogs.com/jerehedu/p/4218560.html

 首先給大家介紹最常用的數據展示組件Grid,使用步驟如下:

  1、頁面中正確引入樣式文件及相應組件

復制代碼
 <link href="<%=request.getContextPath()%>/ui/lib/ligerUI/skins/Aqua/css/ligerui-all.css" rel="stylesheet" type="text/css">

<script type="text/javascript" src="<%=request.getContextPath()%>/ui/lib/jquery/jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="<%=request.getContextPath()%>/ui/lib/ligerUI/js/core/base.js"></script>
<script type="text/javascript" src="<%=request.getContextPath()%>/ui/lib/ligerUI/js/plugins/ligerGrid.js"></script>
復制代碼

   2、  在body中添加div

<div id="maingrid"></div>

  3、  編寫js代碼

復制代碼
<script type="text/javascript">
          $(function(){
              $("#maingrid").ligerGrid({
                  width:600,
                  columns:[
                      {display:"學號",name:"stuNo"},
                      {display:"姓名",name:"stuName"},
                      {display:"性別",name:"stuSex"},
                      {display:"年齡",name:"stuAge"}
                  ]
              });
          });
      </script>
復制代碼

  發布應用后可查看效果如下:

 

  以上只是grid簡單的構建過程,下面看看如何使用grid展示數據

三、使用Grid展示數據

   ligerGrid顯示數據采用 json對象,我們只需要給grid的url屬性指定一個后台地址,默認情況下grid會自動發送異步請求向指定程序請求數據。注意默認情況下grid要求的json數據格式如下:

{Rows:[{},{}],Total:2};

  我們可以通過指定ligerGrid的root和record屬性來改變數據源屬性和數據總記錄屬性。

  以下代碼為后台加載數據的Serlvet的關鍵代碼,如要用來構建grid需要的json格式的字符串數據。

復制代碼
resp.setContentType("text/html;charset=utf-8");
        JSONObject obj = new JSONObject();
        List<Map<String, String>> list =initStudentData();
        obj.put("Rows", list);
        obj.put("Total", list.size());
        PrintWriter out = resp.getWriter();
        out.write(obj.toString());
        out.close(); 
復制代碼

  修改js代碼如下:

復制代碼
var grid=$("#maingrid").ligerGrid({
                  width:600,
                  columns:[
                      {display:"學號",name:"stuNo"},
                      {display:"姓名",name:"stuName"},
                      {display:"性別",name:"stuSex"},
                      {display:"年齡",name:"stuAge"}
                  ],
                  //值為local,數據在客戶端進行分頁
                  dataAction:"local",
                  //數據請求地址
                  url:"main/studentServlet.action?reqCode=findStudents",
                  //數據書否分頁,默認為true
                  usePager:true,
                  pageSize:"8",//分頁頁面大小
                  pageSizeOptions:[8,16,32]//可指定每頁頁面大小
              });
復制代碼

  執行效果如下:

 

  在這里要注意,我們在實際應用中采用的分頁方式基本上都是后台分頁,即在數據庫中分頁,這里主要是演示,直接采用了客戶端分頁,默認情況下dataAction的值為server即為服務器分頁。

  從效果圖中我們可以看到,性別列顯示的內容是代碼,顯然不符合要求,ligerGrid為我們提供了單元格渲染器,可以幫助我們完成我們想要的效果。

  繼續修改grid 列屬性如下:

復制代碼
columns:[
                      {display:"學號",name:"stuNo"},
                      {display:"姓名",name:"stuName"},
                      {display:"性別",name:"stuSex",
                          render:function(rowData){
                              if(rowData.stuSex=="0"){
                                  return "男";
                              }else{
                                  return "女";
                              }
                          }
                      },
                      {display:"年齡",name:"stuAge",
                          render:function(rowData){
                              if(parseInt(rowData.stuAge)<22){
                                  return "<span style='color:red'>"+rowData.stuAge+"</span>";
                              }
                              return rowData.stuAge;
                          }
                      
                      }
                  ] 
復制代碼

  運行程序,效果如下:

 

  由上可知利用render我們可以完成自定義單元格。

  當數據大用戶多的時候,我們不希望用戶打開頁面立即顯示數據,這樣會服務器造成不小的壓力,而是當用戶輸入查詢條件並點擊查詢后,在進行加載數據。

  修改js代碼如下可以實現根據輸入條件加載數據:

復制代碼
  var grid=$("#maingrid").ligerGrid({

                  width:600,
                  columns:[
                      {display:"學號",name:"stuNo"},
                      {display:"姓名",name:"stuName"},
                      {display:"性別",name:"stuSex",
                          render:function(rowData){
                              if(rowData.stuSex=="0"){
                                  return "男";
                              }else{
                                  return "女";
                              }
                          }
                      },
                      {display:"年齡",name:"stuAge",
                          render:function(rowData){
                              if(parseInt(rowData.stuAge)<22){
                                  return "<span style='color:red'>"+rowData.stuAge+"</span>";
                              }
                              return rowData.stuAge;
                          }
                      
                      }
                  ]
                  
              });
              
              $("#btnLoad").click(function(){
                  var name=$("#stuname").val();
                  grid.set({
                      //值為local,數據在客戶端進行分頁
                      dataAction:"local",
                      //數據請求地址
                      url:"main/studentServlet.action?reqCode=findStudents",
                      //數據書否分頁,默認為true
                      usePager:true,
                      pageSize:"8",//分頁頁面大小
                      pageSizeOptions:[8,16,32],//可指定每頁頁面大小
                      parms:[{name:"stuname",value:name}]
                  });
                  grid.loadData();
              });
復制代碼

   運行效果如下:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM