2010-04-10 108 views
2

我有一种情况,我需要根据用户选择的某些搜索条件更新jqgrid。我可以获取数据进行更新,但是我希望在获取新数据时显示加载消息。有人可以让我知道如何得到这个工作吗?jqGrid更新表/默认更新时默认“加载”消息

当前的代码如下

 

var ob_gridContents = $.ajax({ 
url : '/DisplayObAnalysisResults.action?getCustomAnalysisResults', 
data : "portfolioCategory="+ $('#portfolioCategory').val() 
+"&subPortfolioCategory="+ $('#subPortfolioCategory').val() 
+ "&subportfolio=" + $('#subportfolio').val(), 
async : false 
}).responseText; 
var ob_Grid = jQuery('#OBGrid')[0]; 
var ob_GridJsonContents = eval('(' + ob_gridContents + ')'); 
$('#ob_Grid').trigger("reloadGrid"); 
ob_Grid.addJSONData(ob_GridJsonContents); 
ob_Grid = null; 
ob_GridJsonContents = null; 
} 
 

回答

2

如果我正确理解你愿意,我可以推荐你使用jQuery blockUI插件(http://malsup.com/jquery/block/)。那么你就需要更多的使用“异步:假” $就功能的参数,并完成类似下面:

var WaitMsg = function() { 
    jQuery('#main').block({ message: '<h1>Die Daten werden vom Server geladen...</h1>' }); 
}; 
var StopWaiting = function() { 
    jQuery('#main').unblock(); 
}; 

WaitMsg(); 
$.ajax({url : '/DisplayObAnalysisResults.action?getCustomAnalysisResults', 
     data: jQuery.param({portfolioCategory: $('#portfolioCategory').val(), 
          subPortfolioCategory: $('#subPortfolioCategory').val(), 
          subportfolio: $('#subportfolio').val()}), 
     complete: function (data, status) { 
      if (status === "success" || status === "notmodified") { 
       var ob_GridJsonContents = jQuery.parseJSON(data.responseText); 
      ... 
      } 
      StopWaiting(); 
     }, 
     error: function (xhr, st, err) { 
      // display error information 
      StopWaiting(); 
     } 
}); 

我建议你不喜欢

的方式建立的参数“portfolioCategory =” + $( '#portfolioCategory')。VAL() + “& subPortfolioCategory = ”+ $( '#subPortfolioCategory')。VAL() +“ & subportfolio =” + $( '#subportfolio') .val()

因为你可以接收ve编码问题,如果返回的数据是.val()有一些特殊字符。你可以在这种情况下使用JavaScript函数encodeURIComponent方法(如encodeURIComponent方法($( '#portfolioCategory')。VAL())) 或jQuery.param功能,如果你构建像绳子P1 = VAL1 & P2 = val2 & ... pN = valN

问候
奥列格

+0

感谢奥列格,我现在使用的方法是,我重新设置网址,并使用触发方法重装。我将根据您的建议添加编码调用。 – JVXR 2010-04-16 17:27:11