我有一个带有几个字段的jqGrid,它们动态填充filterToolbar中的下拉框。我希望在“添加记录”对话框中显示相同的结果,为“产品”和“环境”字段提供下拉选择器而不是文本输入字段。如您所见,我正在尝试在beforeShowForm事件中执行此操作。这是适当的地方吗?将值设置为先前定义的prodValues和envValues vars会很好,但如果有必要,我可以再次发出ajax请求(我已经尝试过也失败了)。
按原样,代码仍会生成包含Product和Environment字段的文本输入的表单。如何将它们更改为选择器?
$(function () {
var grid = $("#PSGrid");
var prodValues = $.ajax({
url: "jqGridHandler.ashx?oper=pVals",
async: false,
success: function (data) {
}
}).responseText;
var envValues = $.ajax({
url: "jqGridHandler.ashx?oper=eVals",
async: false,
success: function (data) {
}
}).responseText;
var lastsel = -1;
// build the grid
grid.jqGrid({
url: 'jqGridHandler.ashx',
editurl: 'jqGridEditor.ashx',
datatype: 'json',
height: 550,
width: 'auto',
colNames: ['ID', 'Product', 'Environment', 'Hostname', 'IP', 'Description', 'Type', 'Ports Used'],
colModel: [
{ name: 'ID', index: 'ID', width: 50, sortable: true, hidden: false, editable: false, key: true },
{
name: 'Product', index: 'Product', width: 125, sortable: true, editable: true,
stype: 'select', searchoptions: { value: prodValues, sopt: ['eq'] }
},
{
name: 'Environment', index: 'Environment', width: 100, sortable: true, editable: true,
stype: 'select', searchoptions: { value: envValues, sopt: ['eq'] }
},
{ name: 'Hostname', index: 'Hostname', width: 200, sortable: true, editable: true },
{ name: 'IP', index: 'IP', width: 125, sortable: false, editable: true },
{ name: 'Description', index: 'Description', width: 200, sortable: true, editable: true },
{ name: 'Type', index: 'Type', width: 75, sortable: true, editable: true },
{ name: 'Ports Used', index: 'Ports Used', width: 80, sortable: false, editable: true }
],
rowNum: 1000, // hack to show everything; there's probably a better property to use than this
pager: '#PSGridPager',
sortname: 'ID',
pgbuttons: false,
pgtext: null,
viewrecords: false,
sortorder: 'asc',
ignoreCase: true,
caption: 'Click a row to edit. [Enter] to save, [Esc] to cancel.',
loadonce: true,
onSelectRow: function (id) {
if (id && id !== lastsel) {
grid.jqGrid('restoreRow', lastsel);
grid.jqGrid('editRow', id, true);
lastsel = id;
}
}
});
grid.jqGrid('filterToolbar', { stringResult: true, searchOnEnter: true, defaultSearch: "cn" });
grid.jqGrid('navGrid', '#PSGridPager', { edit: false, add: true, del: true, search: false, refresh: true, paging: false },
{ /* edit options */ },
{ /* add options */
closeOnEscape: true,
width: 400,
beforeShowForm: function (formid) {
$(this).setColProp('Product', { editoptions: { value: prodValues } });
$(this).setColProp('Environment', { editoptions: { value: envValues } });
}
});
grid.jqGrid('navButtonAdd', '#PSGridPager', {
caption: "Export to Excel",
onClickButton: function () {
grid.jqGrid('excelExport', { url: "jqGridHandler.ashx" });
}
});
});
答案 0 :(得分:0)
在colModel中将其配置为选择:
formatter:'select', edittype:"select", editoptions:{ value: prodValues }
然后删除你的beforeShowForm代码。