Jqgrid пользовательский форматер и режим редактирования
Похоже, что при использовании специального средства форматирования ячейка застревает в режиме редактирования, и ранее отредактированная строка никогда не восстанавливается.
JS, сетка определена здесь
$(priceListGrid).jqGrid({
datatype: 'local',
url: common.getServerPath() + 'controller/action',
mtype: 'POST',
jsonReader: common.jqgrid.jsonReader('Id'),
colModel: [
{ name: 'MethodCode', label: 'MethodCode', index: 'MethodCode', hidden: true },
{ name: 'PriceCode', label: 'Price Code', index: 'PriceCode', width: '20px' },
{ name: 'Description', label: 'Description', index: 'Description', width: '34px' },
{ name: 'RoundTo', label: 'RoundTo', index: 'RoundTo', width: '10px' },
{
name: 'MinPrice',
label: 'Min Pr',
index: 'MinPrice',
width: '15px',
align: 'right',
formatter: customCurFormatter,
editable: true,
editrules: {
number: true,
minValue: 0,
custom: true,
custom_func: validateMinPrice
}
}
],
caption: 'Price Entity List',
hidegrid: false,
ignoreCase: true,
viewrecords: true,
recordtext: '{2} Entity(ies).',
autowidth: true,
shrinkToFit: true,
scroll: 1,
sortname: 'PriceCode',
sortorder: 'asc',
rowNum: 500,
altRows: true,
altclass: 'gridAltRowClass',
pager: '#pagerEntityPriceListDetails',
onCellSelect: priceItemSelect,
onSelectRow: onSelectPrice,
afterSubmitCell: function (rowid) {
this.setRowData(rowid, info.Data, null);
},
loadComplete: priceListEntityLoadComplete,
loadError: function (xhr, status, error) {
common.ajax.alsJsonError(xhr, status, error);
//stopDataLoading();
}//,
//loadBeforeSend: function () { isDataLoadingCount++; },
//beforeSelectRow: function () { return !getIsDataLoading(); }
})
это форматтер
var customCurFormatter = function (cellvalue, options, rowObject) {
return cellvalue.toFixed(rowObject.RoundTo);
}
Когда он используется, в отличие от formatter:currency
при переходе на следующую строку ячейка застряла в режиме редактирования.
Любые идеи были бы хорошы.
1 ответ
Решение
Текущий код пользовательского форматера неверен, потому что toFixed
метод может быть применен к Number
а не нанизывать. cellvalue
имеет String
введите хотя бы во время редактирования. Минимальные изменения кода форматера должны быть
var customCurFormatter = function (cellvalue, options, rowObject) {
return Number(cellvalue).toFixed(rowObject.RoundTo);
}
У вашего кода много других проблем. Например, настоятельно рекомендуется всегда определять неотформатированный обратный вызов вместе с formatter
,