2010-08-20 81 views
3

嘿,大家好!JQGrid重绘速度慢

所以我现在在我的应用程序一段时间了jqGrid的和速度电网处理不当的真正困扰我,直到我开始优化。

如果发现即使我有一个小网格(每页20个项目)悬停突出显示速度很慢,并且如果网格碰巧需要页面上的滚动条,页面的滚动确实很慢。

我试过异步帖子也loadonce:真,他们都画慢。

我正在使用jquery.ui.theme css。

我已经一起删除了分页,因此网格绝对只在屏幕上包含20个项目,并且悬停的绘图仍然很慢。

只是为了确保它在我的页面上没有任何其他内容,我将网格的显示设置为无,并且页面像往常一样快速运行 - 就像我怀疑的那样。

使用IE8调试器,我使用profiler来测量我的javascript和html的速度,这些速度非常快 - 所以它绝对是屏幕上的网格绘图。

我很感激任何和所有帮助或建议以提高性能。

我会附上我的网格定义(这是相当大的),万一你可能认为它可能是一些有:

$("#tblVariables").jqGrid({ 
     url: '/StudyAdmin/GetVariable.aspx?FilterType=' + Filter + '&SelectedFolder=' + SelectedFolder + '&SelectedGroup=' + SelectedGroup, 
     datatype: "json", 
     mtype: "POST", 
     colNames: ['Variable Name', 'Hidden Original Text', 'Original Text', 'Label', 'Hidden', 'Groups', 'HiddenGroups'], 
     colModel: [ 
      { name: 'VarName', index: 'VarName', editable: false }, 
      { name: 'VarOriginalText', index: 'VarOriginalText', hidden: true, editable: true, editrules: { edithidden: true} }, 
      { name: 'VarOriginalTextToShow', index: 'VarOriginalTextToShow', editable: false, sortable: false }, 
      { name: 'VarReportingText', index: 'VarReportingText', editable: true }, 
      { name: 'HiddenVar', index: 'HiddenVar', editable: true, edittype: "select", editoptions: { value: { "true": "True", "false": "False"}} }, 
      { name: 'Groups', index: 'Groups', editable: false }, 
      { name: 'HiddenGroups', index: 'HiddenGroups', hidden: true, editable: true, editrules: { edithidden: true} } 
     ], 
     editurl: "/StudyAdmin/Editvariable.aspx", 
     height: "100%", 
     gridComplete: function() { 
      var grid = jQuery("#tblVariables"); 
      var ids = grid.jqGrid('getDataIDs'); 
      for (var i = 0; i < ids.length; i++) { 
       var rowId = ids[i]; 
       var splitGroups = $('#tblVariables').getCell(rowId, 'HiddenGroups').split(","); 
       if (splitGroups.length == 1 && splitGroups[0] == "") splitGroups = ""; 
       var GroupSelect = "<select id='Group_" + rowId + "' onchange='filterGroup(this)'>"; 
       if (splitGroups.length > 0) GroupSelect += "<option value='HasSelectGroup'>Select Group</option>"; 
       else GroupSelect += "<option value='NotHasSelectGroup'>No Groups</option>"; 
       for (var k = 0; k < splitGroups.length; k++) { 
        GroupSelect += "<option value='" + splitGroups[k] + "'>" + splitGroups[k] + "</option>"; 
       } 
       //add all groups in here 
       GroupSelect += "</select>"; 
       grid.jqGrid('setRowData', rowId, { Groups: GroupSelect }); 
      } 
      setGridWidth($("#VariableGridContentConainer").width() - 19); 
     }, 
     afterInsertRow: function (rowid, rowdata, rowelem) { 
      $("#" + rowid).addClass('jstree-draggable'); 
     }, 
     ondblClickRow: function (id, ri, ci) { 
      lastSelRow = id; 
      $("#tblVariables").jqGrid('editRow', id, true); 
     }, 
     onSelectRow: function (id) { 
      if ($('#QuestionTree').find("#FQ" + id).attr("id") !== undefined) { 
       $.jstree._focused().select_node("#FQ" + id); 
      } 
      if (id == null) { 
       //$("#tblAnswers").setGridParam({ url: "/StudyAdmin/GetAnswers.aspx", page: 1 }).trigger('reloadGrid'); 
       $('#tblAnswers').GridUnload(); 
       loadAnswersGrid("-1"); 
      } else { 
       //$("#tblAnswers").setGridParam({ url: "/StudyAdmin/GetAnswers.aspx?id=" + id, page: 1 }).trigger('reloadGrid'); 
       $('#tblAnswers').GridUnload(); 
       loadAnswersGrid(id); 
       if (id && id !== lastSelRow) $("#tblVariables").jqGrid('saveRow', lastSelRow); 
      } 
     }, 
     viewrecords: true, 
     rowNum: 20, 
     loadonce: true, 
     pager: jQuery('#pagernav'), 
     sortname: 'VarName', 
     sortorder: "asc", 
     imgpath: '/Content/Images/', 
     jsonReader: { 
      root: "rows", 
      page: "page", 
      total: "total", 
      records: "records", 
      repeatitems: true, 
      cell: "cell", 
      id: "id" 
     } 
    }); 
+0

你可以发布完整的JavaScript代码(例如函数filterGroup,setGridWidth,loadAnswersGrid等),HTML代码可以看到具有ID VariableGridContentConainer,QuestionTree,FQ等元素。此外,您可以从服务器保存一个测试JSON响应(您可以使用Fiddler,请参阅http://www.fiddler2.com/fiddler2/或Firebug)。然后,无需运行服务器就可以重现问题。看起来你的罐头可以很好地改进,但必须有完整的代码才能更精确。 – Oleg 2010-08-20 11:09:57

回答

9

你没有发布完整的JavaScript代码,所以我写了一些说明如何根据现有信息对jqGrid进行优化。

  1. 你最好避免afterInsertRow用法,做同样的工作,gridCompleteloadComplete。然后,您可以在jqGrid的定义中添加gridview: true参数,并且网格将快速构建(有关更多详细信息,请参阅jqgrid, firefox and css- text-decoration problem)。您目前在afterInsertRow中的操作可以很容易地由jQuery('.jqgrow',jQuery('#tblVariables')).addClass('jstree-draggable');替换为loadCompletegridComplete
  2. 根据隐藏的HiddenGroups列的列包构造Groups列的值。您从服务器发送的包含Groups列的数据似乎会被覆盖。您可以构建Groups列的相同列表,其编号为Groupscustom formatter。那么可能你可以删除不需要的HiddenGroups列。有关自定义格式化程序的示例,请参阅jqGrid: Editable column that always shows a select,作为custom editing的示例,请参阅Add multiple input elements in a custom edit type field。大概定义custom unformater也会对你很有意思。
  3. 这是一个有点味道的问题,但使用formatter:'checkbox'HiddenVar似乎是我适当的。此外可以看到,您从服务器发送“True”或“False”字符串作为列的值。 1和0的发送遵循相同的结果,但减小发送的数据的大小 。
  4. 您可以减少您的JavaScript的大小,如果你删除喜欢imgpath一些默认值(如jsonReader)或过时的值(见http://www.trirand.com/jqgridwiki/doku.php?id=wiki:upgrade_from_3.4.x_to_3.5)和colModel(如editable: false)删除默认值。

jqGrid的一些其他一般优化方法的描述,你可以在what is the best way to optimize my json on an asp.net-mvc site找到。

更新:可能你并不需要在Groups中插入select元素。除此之外,只有在选定行或处于编辑模式时才可以执行此操作。从整个Groups中删除选择元素的构造可以提高网格的性能并简化代码。您可以使用editoptionsvalue作为函数或使用editoptions的其他可能性。 onchange事件与选择的绑定可以随后用type: 'change'替换为dataEvents

+1

你好! 我刚刚看了一下我的邮件。非常感谢你的回复!你真的很有帮助^ _^ 当我回到办公室并让你知道我的结果时,我会尝试一些改变。 我真的很感谢你的深思熟虑和有益的答复。 – Bob 2010-08-22 18:02:12