我正在尝试将 JqGrid 与 WebAPI 一起使用。要访问 webAPI,我们需要设置自定义标头。例如:
headers: {
'Username': 'Administrator'
},
我可以通过 AJAX 来加载网格。但是,我想利用 JqGrid 支持的创建/编辑/删除。问题是 JqGrid 似乎不允许我在调用中添加标题:
$("#btnCreate").click(function () {
jQuery("#myGrid").jqGrid('editGridRow', "new", { reloadAfterSubmit: true, url: 'htp://localhost/colorfolder/insert' });
});
您如何将标题添加到创建中?
我无法将标题添加到网格的负载中,我什至尝试扩展 onclickSubmit 但无济于事。
这是代码:
<head>
<title>htp://stackoverflow.com/questions/6831306/load-local-json-data-in-jqgrid-without-addjsonrows</title>
<meta htp-equiv="Content-Type" content="text/html; charset=utf-8" />
<link rel="stylesheet" type="text/css" href="htp://ajax.googleapis.com/ajax/libs/jqueryui/1.8.14/themes/redmond/jquery-ui.css" />
<link rel="stylesheet" type="text/css" href="htp://www.ok-soft-gmbh.com/jqGrid/jquery.jqGrid-4.1.2/css/ui.jqgrid.css" />
<script src="js/jquery-1.7.2.min.js" type="text/javascript"></script>
<script src="js/i18n/grid.locale-en.js" type="text/javascript"></script>
<script src="js/jquery.jqGrid.js" type="text/javascript"></script>
<script type="text/javascript">
$.jgrid.no_legacy_api = true;
$.jgrid.useJSON = true;
</script>
<script type="text/javascript">
function CallWebAPI() {
jQuery.support.cors = true;
var webAPIurl = "htp://localhost/colorfolder/list";
$.ajax({
url: webAPIurl,
headers: {
'Username': 'Administrator'
},
contentType: "application/json; charset=utf-8",
type: 'GET',
dataType: 'json',
data: "{}",
success: function (data) {
GetDataFields(data);
},
error: function (x, y, z) {
alert(x + '\n' + y + '\n' + z);
}
});
}
</script>
<script type="text/javascript">
var lastsel2
function GetDataFields(data) {
'use strict';
var data = {
"page": "1",
"records": "3",
"rows": data
},
grid = $("#myGrid");
grid.jqGrid({
colModel: [
{ name: 'FolderID', index: 'FolderID', width: "200" },
{ name: 'FolderDescription', index: 'FolderDescription', width: "105"}
],
onSelectRow: function (id) {
if (id && id !== lastsel2) {
jQuery('#myGrid').jqGrid('restoreRow', lastsel2);
jQuery('#myGrid').jqGrid('editRow', id, true);
lastsel2 = id;
}
},
pager: '#myGridPageControls',
datatype: "jsonstring",
datastr: data,
jsonReader: { repeatitems: false },
rowNum: 25,
viewrecords: true,
multiselect: false,
caption: "Folder",
height: "auto",
ignoreCase: true
});
$("#btnCreate").click(function () {
jQuery("#myGrid").jqGrid('editGridRow', "new", { reloadAfterSubmit: true, url: 'htp://localhost/colorfolder/insert' });
});
}
var grid = $("#myGrid"); // your jqGrid (the <table> element)
var orgEditGridRow = grid.jqGrid.editGridRow; // save original function
var folder = { "Params": "<Filters><FolderTypeID>1</FolderTypeID><FolderDescription>Test</FolderDescription></Filters>" };
jQuery.support.cors = true;
$.jgrid.extend({
editGridRow: function (rowid, p) {
$.extend(p, { // modify some parameters of editGridRow
onclickSubmit: function (formid) {
$.ajaxSetup({
headers: {
'Username': 'Administrator'
},
type: 'POST',
data: JSON.stringify(folder),
contentType: "application/json;charset=utf-8",
success: function (data) {
alert("inserting");
},
error: function (x, y, z) {
alert(x + '\n' + y + '\n' + z);
var alerting = "alert";
}
});
}
});
orgEditGridRow.call(this, rowid, p);
}
});
CallWebAPI();
</script>
</head>
<body>
<table id="myGrid"><tr><td/></tr></table>
<div id="myGridPageControls"></div>
<input type="button" id="btnCreate" value="Create" />
</body>