2011-11-09 71 views
1

我有一個jqGrid,如果點擊標題進行排序,我的所有網格數據都會消失,我不知道爲什麼會發生這種情況。這是一個sample page我製作了repro的問題。jqGrid客戶端數據在點擊排序列時消失

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
    <title>Disappearing Sort Repro</title> 
    <link type="text/css" rel="Stylesheet" href="js/jQuery/plugins/jqGrid4/ui.jqgrid.css" /> 

</head> 
<body> 
    <table id="ooTruckGrid"> 
    </table> 
    <div id="ooTruckPager"> 
    </div> 
    <script language="javascript" type="text/javascript" src="js/jquery/jquery-1.6.2.js"></script> 
    <script language="javascript" type="text/javascript" src="js/jquery/jquery-ui.js"></script> 
    <script language="javascript" type="text/javascript" src="js/jquery/plugins/jqGrid4/grid.locale-en.js"></script> 
    <script language="javascript" type="text/javascript" src="js/jQuery/plugins/jqGrid4/jquery.jqGrid.js"></script> 
    <script language="javascript" type="text/javascript"> 
     _truckList = []; 

     $(document).ready(function() { 
      $("#ooTruckGrid").jqGrid({ 
       datatype: "clientSide", 
       colNames: ['id', 'VIN', 'Plate', 'Make', 'Model', 'Year', 'RFID #', 'Description'], 
       colModel: [ 
        { name: 'id', index: 'id', hidden: true, sorttype: "int" }, 
        { name: 'vin', index: 'vin', width: 120, sorttype: "text" }, 
        { name: 'plate', index: 'plate', width: 75, sorttype: "text" }, 
        { name: 'make', index: 'make', width: 80, sorttype: "text" }, 
        { name: 'model', index: 'model', width: 80, sorttype: "text" }, 
        { name: 'year', index: 'year', width: 40, sorttype: "int" }, 
        { name: 'rfidNo', index: 'rfidNo', width: 50, sorttype: "text" }, 
        { name: 'description', index: 'description', width: 100, sortable: false } 
       ], 
       datatype: 'local', 
       hidegrid: false, 
       jsonReader: { 
        repeatitems: false 
       }, 
       loadonce: true, 
       multiselect: true, 
       pgbuttons: false, 
       pginput: false, 
       rowNum: '', 
       pager: '#ooTruckPager', 
       sortable: false, 
       viewrecords: true 
      }); 

      // Add truck   
      addTruckData(-1, 0, "11111111111111111", "Make 1", "Model 1-1", "2009", "US", "WA", "1D1D1D", "", "Test truck 1"); 
      addTruckData(-1, 0, "22222222222222222", "Make 2", "Model 2-1", "2010", "US", "WA", "2A2A2A", "11111", "Test truck 2"); 
      addTruckData(-1, 0, "33333333333333333", "Make 2", "Model 2-2", "2011", "US", "WA", "3B3B3B", "", "Test truck 3"); 
      addTruckData(-1, 0, "44444444444444444", "Make 1", "Model 1-2", "2006", "US", "WA", "4C4C4C", "22222", "Test truck 4"); 
      addTruckData(-1, 0, "55555555555555555", "Make 3", "Model 3-1", "2003", "US", "WA", "5E5E5E", "", "Test truck 5"); 
     }); 

     function addTruckData(rowId, id, vin, make, model, year, country, state, 
      plate, rfid, description) { 

      var rowId = -1; 
      var method = ''; 

      var truck = new truckData(-1, // rowId 
      id, vin, make, model, year, country, 
      state, plate, rfid, description); 

      if (_truckList.length > 0) { 
       for (var xx = 0; xx < _truckList.length; xx++) { 
        if (_truckList[xx].vin == vin) { 
         // The vin is already in the list, update it. 
         rowId = _truckList[xx].rowId; 
         break; 
        } 
       } 
      } 

      if (rowId == -1 && _truckList.length == 0) { 
       _truckList = [truck]; 
       rowId = 0; 
       method = 'addRowData'; 
      } 
      else if (rowId == -1) { 
       rowId = _truckList.length; 
       _truckList.push(truck); 
       method = 'addRowData'; 
      } 
      else { 
       _truckList[rowId] = truck; 
       method = 'setRowData'; 
      } 

      truck.rowId = rowId; 
      result = $('#ooTruckGrid').jqGrid(method, rowId, truck.toJqGridData()); 
     } 

     function truckData(rowId, truckId, vin, make, model, year, country, state, plateNum, description, rfid, truckType) { 
      return { 
       rowId: rowId, 
       id: truckId, 
       vin: $.trim(vin), 
       make: make, 
       model: model, 
       year: year, 
       plateCountry: country, 
       plateState: state, 
       plateNumber: $.trim(plateNum), 
       description: $.trim(description), 
       rfid: $.trim(rfid), 
       truckType: truckType, 
       toJqGridData: function() { 
        return { "id": this.id, 'action': '', 'vin': this.vin, 
         'plate': this.plateCountry + '-' + this.plateState + '-' + 
         this.plateNumber, 'make': this.make, 'model': this.model, 
         'year': this.year, 'rfidNo': this.rfid, 
         'description': this.description 
        }; 
       } 
      }; 
     } 
    </script> 
</body> 
</html> 

如果轉到該鏈接,然後單擊其中一個標題,則所有數據消失而不是排序網格。

回答

5

在列分類中產生數據消失的錯誤是選項rowNum: ''。如果您不需要分頁數據,您應該爲rowNum設置一些足夠大的值,如rowNum: 10000。這種改變將解決你的主要問題。

你的代碼有許多其他的小錯誤或爛筆頭部分,我想提一提:

  • 您測試頁不包括jquery-ui.css這是非常重要。另一方面,你包括jquery-ui.js這是jqGrid不需要的。只有在使用一些jQuery UI功能時才應該包含它。
  • addTruckData函數包含rowId參數,但您可以使用相同名稱定義局部變量並在代碼中稍後分配值var rowId = -1。當然這是錯誤的。
  • 您應該在頁眉中包含<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  • 您應該刪除已棄用language="javascript"屬性<script>
  • 如果您想要正確的XHTML 1.0 Transitional頁面,您應該在<table>元素內包含一個空單元格<tr><td/></tr>。在jqGrid初始化期間,空單元格將被刪除。
  • 您在JavaScript代碼中使用<&字符。因此,爲了獲得正確的XHTML代碼,您應該修改代碼,或者在腳本的開始處包含行//<![CDATA[,並在行尾加上//]]>行。
  • 你應該遵循JavaScript標準的類,並刪除功能truckDataTruckData
  • 儘可能使用較少的全局變量和全局函數。例如功能TruckDataaddTruckData像變量_truckList(更好truckList)可以的$(document).ready(function() {/*here*/});
  • 內移動使用存在之前,您應該定義變量。例如,如果沒有定義,則使用result。在這種情況下,result將被解釋爲全局變量,並將作爲屬性添加到windows對象。
  • 在同一個網格中使用datatype: "clientSide"datatype: 'local'。您應該刪除datatype: "clientSide"
  • 您應該刪除loadonce: true,因爲在datatype: 'local'的情況下它沒有任何意義並且將被忽略。
  • 您應該刪除colModel的屬性,這些屬性默認爲sorttype: "text",並刪除jqGrid options,這些默認值也是sortable: false。另一方面,您可以考慮包含height: 'auto'參數。
  • 我建議您使用JSLint來提高JavaScript代碼的質量,並使用W3 validator來驗證HTML標記。

我修改了您的頁面一次,以顯示如何完成上述更改。演示here沒有JSLint或W3驗證器錯誤。

-1

添加以下行中的jqGrid創建範圍:

rowNum: 9007199254740992

這將最大容量的行的jqGrid