2013-07-27 25 views
0

我正在试图将jquerygrid插件实现到我的asp.net mvc4应用程序。但即时通讯卡住了。需要你的帮助。写了所有的代码,我只用json数据获得了白页。我不知道为什么。Asp.net mvc4 jquerygrid不显示

我的看法如下:

@model Fancy.Management.Model.User.IndexModel 
@{ 
ViewBag.Title = "Index"; 
} 
<script type="text/javascript"> 
jQuery(document).ready(function(){ 
    jQuery("#list").jqGrid({ 
     url:'@Html.Action("Index","User")', 
     datatype: 'json', 
     mtype: 'GET', 
     colNames:['Id','Votes','Title'], 
     colModel :[ 
      {name:'Id', index:'Id', width:40, align:'left' }, 
      {name:'Votes', index:'Votes', width:40, align:'left' }, 
      {name:'Title', index:'Title', width:200, align:'left'}], 
     pager: jQuery('#pager'), 
     rowNum:10, 
     rowList:[5,10,20,50], 
     sortname: 'Id', 
     sortorder: "desc", 
     viewrecords: true, 
     imgpath: '/scripts/themes/coffee/images', 
     caption: 'My first grid' 
    }); 
}); 
</script> 

<table id="list" class="scroll" cellpadding="0" cellspacing="0"></table> 
<div id="pager" class="scroll" style="text-align:center;"></div> 

,如下所示我的操作方法:

public ActionResult Index(string sidx, string sord, int? page, int? rows) 
    { 
     var jsonData = new 
     { 
      total = 1, 
      page = 1, 
      records = 3, 
      rows = new[]{ 
    new{Id=1,cell=new[] {"1","-7","Is this good question?"}}, 
    new{Id=2,cell=new[] {"2","15","Is this really?"}}, 
    new{Id=3,cell=new[] {"3","23","Why is the sky blue?"}} 
    } 
     }; 
     return Json(jsonData, JsonRequestBehavior.AllowGet); 
    } 

例外,我得到了如下图所示:

enter image description here

回答

1

Index操作未返回View,所以您创建的视图永远不会被使用。动作只能返回JSON数据:

return Json(jsonData, JsonRequestBehavior.AllowGet); 

这就是为什么你看到在浏览器中的JSON数据当您请求Index行动。

相反,你需要返回一个视图(与IndexModel一个实例,你似乎并不在代码):然后

return View(someInstanceOfIndexModel); 

的jqGrid的是要需要使用不同的动作获取其JSON数据,因为AJAX请求是一个不同于最初加载页面的请求。事情是这样的:

url:'@Html.Action("IndexData","User")', 

的操作方法,你目前Index会则(使用上面的示例)来处理Ajax请求被重命名为类似IndexData

最终,这里的操作顺序是:

  1. 浏览器请求Index
  2. Index返回一个View(由任何必要的视图模型填充)。
  3. 由于有问题的视图包含JavaScript代码,因此该代码将由浏览器执行。
  4. JavaScript代码向另一个操作发出第二个请求(我称之为IndexData,但您可以随意调用它)。
  5. 该其他操作返回Json与网格所需的数据。
  6. 客户端JavaScript代码接收数据并填充网格。
+0

谢谢大卫问题已解决 – fuat