jqueryグリッドにjsonデータを入力しようとしています:
public ActionResult DataHandler()
{
List<Employee> employees = EmployeeRepository.GetEmployees();
return Json(new
{
employees
},
JsonRequestBehavior.AllowGet);
}
私のクライアント側のコード:
$(document).ready(function () {
alert("Code Fired!");
var source =
{
url: '@Url.Action("DataHandler", "Home")',
datatype: "json",
datafields: [{ name: "FirstName" }, { name: "LastName" }, { name: "Product" }, { name: "Price", type: "float" }, { name: "Quantity", type: "int" }, { name: "Total", type: "float"}]
};
var dataAdapter = new $.jqx.dataAdapter(source);
$("#jqxgrid").jqxGrid(
{
source: dataAdapter,
columns: [
{ text: 'First Name', dataField: 'FirstName', width: 100 },
{ text: 'Last Name', dataField: 'LastName', width: 100 },
{ text: 'Product', dataField: 'Product', width: 180 },
{ text: 'Quantity', dataField: 'Quantity', width: 80, cellsalign: 'right' },
{ text: 'Unit Price', dataField: 'Price', width: 90, cellsalign: 'right', cellsformat: 'c2' },
{ text: 'Total', dataField: 'Total', cellsalign: 'right', minwidth: 100, cellsformat: 'c2' }
]
});
});
これが私の見解です:
@{
ViewBag.Title = "DataHandler";
}
@section scripts
{
@Content.Script("GetGridData.js",Url)
}
<h2>DataHandler</h2>
<div id="jqxgrid"></div>
このようにコードを設定すると、入力された JSON データがブラウザに返され、クエリ コードが起動されることはありません。少なくとも jquery コードが起動することがわかります。
コントローラー コードから jquery my json データを渡し、それをグリッドに表示するようにページを設定するにはどうすればよいですか?