2012-02-08 38 views
1

繼續使用this topic我想將擴展節點保存在cookie中。這是最好的方法嗎?在cookie中發送展開的TreeGrid節點

我不確定在的方式JSON數據檢查。

爲什麼expandRow不起作用?

var gridId = "#table"; 
var grid = $(gridId); 
grid.jqGrid({ 

... 

loadComplete: function() { 
var ids = grid.jqGrid('getDataIDs'); 

var cookie = $.cookie(gridId + '_expanded'); 
var expanded = false; 

if (typeof(cookie) == 'string') 
var expanded = JSON.parse(cookie); 

for (var i=0;i<ids.length;i++) { 
var id=ids[i]; 
var row_data = $(this).jqGrid('getRowData', id); 

if (expanded && id in expanded && expanded[id] == 'true') 
$(gridId + ' tr#' + id + ' div.treeclick').trigger("click"); 
//Why it doesn't work? 
//grid.jqGrid('expandRow', row_data); 

} 
} 

... 

}); 

function setCookie() { 
      var ids = grid.jqGrid('getDataIDs'); 

      var expanded = Object(); 
      var string = ''; 

      for (var i=0;i<ids.length;i++) {  
       var id=ids[i]; 
       var rowData = grid.jqGrid('getRowData', id);     

       if (rowData.parent != '' && grid.jqGrid('isVisibleNode', rowData) === true) 
        expanded[rowData.parent] = true 
      } 

      for (e in expanded) 
       string += '"' + e + '":' + '"' + expanded[e] + '",'; 

      $.cookie(gridId + '_expanded', '{'+ string.substring(0, string.length - 1) + '}', { expires: 365 });  
} 

var orgExpandNode = $.fn.jqGrid.expandNode, orgCollapseNode = $.fn.jqGrid.collapseNode; 

     $.jgrid.extend({ 
      expandNode : function(rc) { 
       orgExpandNode.call(this, rc); 
       setCookie();    
      }, 
      collapseNode : function(rc) { 
       orgCollapseNode.call(this, rc); 
       setCookie();       
      }, 
}); 

P.S.我總是得到這個愚蠢的警報:)

您的文章沒有太多的上下文來解釋代碼段;請更清楚地解釋你的情況。

+0

你加載樹電網在使用Ajax一旦從服務器加載孩子每花費樹節點的?我會盡量在稍後檢查問題。在所有我會建議你閱讀[答案](http://stackoverflow.com/a/8436273/315935)和[這一個](http://stackoverflow.com/a/8547852/315935)我在哪裏使用'localStorage'而不是Cookie。可能它也是更好的方法。 – Oleg 2012-02-08 12:19:18

+0

所有的數據(關於父母和孩子)在網格建設期間通過Ajax傳遞一次 – dr0zd 2012-02-08 12:49:13

+0

我的問題是所有的數據是否通過* 1加載* Ajax請求會在樹節點擴展期間按需加載。 – Oleg 2012-02-08 12:59:06

回答

5

我建議您使用localStorage代替cookies。我在the answer中描述了原因。我根據the answeranother one的演示製作了the demo。對於the demo我使用了我最近的一個answer的測試數據。

嘗試擴大the demo一些樹節點並重新加載網格與F5。您將看到所有展開的行在重新加載後都保持展開狀態。

,你會發現下面的演示代碼:

var $grid = $('#treegridCompanies'), 
    saveObjectInLocalStorage = function (storageItemName, object) { 
     if (typeof window.localStorage !== 'undefined') { 
      window.localStorage.setItem(storageItemName, JSON.stringify(object)); 
     } 
    }, 
    removeObjectFromLocalStorage = function (storageItemName) { 
     if (typeof window.localStorage !== 'undefined') { 
      window.localStorage.removeItem(storageItemName); 
     } 
    }, 
    getObjectFromLocalStorage = function (storageItemName) { 
     if (typeof window.localStorage !== 'undefined') { 
      return JSON.parse(window.localStorage.getItem(storageItemName)); 
     } 
    }, 
    myColumnStateName = function (grid) { 
     return window.location.pathname + '#' + grid[0].id; 
    }, 
    idsOfExpandedRows = [], 
    updateIdsOfExpandedRows = function (id, isExpanded) { 
     var index = $.inArray(id, idsOfExpandedRows); 
     if (!isExpanded && index >= 0) { 
      idsOfExpandedRows.splice(index, 1); // remove id from the list 
     } else if (index < 0) { 
      idsOfExpandedRows.push(id); 
     } 
     saveObjectInLocalStorage(myColumnStateName($grid), idsOfExpandedRows); 
    }, 
    orgExpandRow = $.fn.jqGrid.expandRow, 
    orgCollapseRow = $.fn.jqGrid.collapseRow; 

idsOfExpandedRows = getObjectFromLocalStorage(myColumnStateName($grid)) || []; 

$grid.jqGrid({ 
    url: 'SPATEN-TreeGrid2.json', 
    datatype: 'json', 
    ajaxGridOptions: { contentType: "application/json" }, 
    jsonReader: { 
     id: "CompanyId", 
     cell: "", 
     root: function (obj) { return obj.rows; }, 
     page: function() { return 1; }, 
     total: function() { return 1; }, 
     records: function (obj) { return obj.rows.length; }, 
     repeatitems: true 
    }, 
    beforeProcessing: function (data) { 
     var rows = data.rows, i, l = rows.length, row, index; 
     for (i = 0; i < l; i++) { 
      row = rows[i]; 
      index = $.inArray(row[0], idsOfExpandedRows); 
      row[5] = index >= 0; // set expanded column 
      row[6] = true;  // set loaded column 
     } 
    }, 
    colNames: ['CompanyId', 'Company'], 
    colModel: [ 
     { name: 'CompanyId', index: 'CompanyId', width: 1, hidden: true, key: true }, 
     { name: 'Company', index: 'Company', width: 500 } 
    ], 
    height: 'auto', 
    pager: '#pager', 
    rowNum: 10000, 
    sortable: false, 
    treeGrid: true, 
    treeGridModel: 'adjacency', 
    ExpandColumn: 'Company' 
}); 
$grid.jqGrid('navGrid', '#pager', {edit: false, add: false, del: false, search: false}); 
$grid.jqGrid('navButtonAdd', '#pager', { 
    caption: "", 
    buttonicon: "ui-icon-closethick", 
    title: "Clear saved grid's settings", 
    onClickButton: function() { 
     removeObjectFromLocalStorage(myColumnStateName($(this))); 
     window.location.reload(); 
    } 
}); 
$.jgrid.extend({ 
    expandRow: function (rc) { 
     //alert('before expandNode: rowid="' + rc._id_ + '", name="' + rc.name + '"'); 
     updateIdsOfExpandedRows(rc._id_, true); 
     return orgExpandRow.call(this, rc); 
    }, 
    collapseRow: function (rc) { 
     //alert('before collapseNode: rowid="' + rc._id_ + '", name="' + rc.name + '"'); 
     updateIdsOfExpandedRows(rc._id_, false); 
     return orgCollapseRow.call(this, rc); 
    } 
}); 
+0

謝謝!!!!!! – dr0zd 2012-02-09 09:34:03

+0

@ gv0zd:不客氣! – Oleg 2012-02-09 10:09:18