おそらく誤解です。カスタムフォーマッターのインターフェースはjqGridによって定義されます。カスタムフォーマッタに追加のパラメータを含めるには、jqGridのソースコードを変更する必要があります。
良いニュースは、標準のカスタムフォーマッタを実際に拡張する必要がないことです。その代わりに、おそらくコードを共有したいだけです。したがって、共通コードを次のような関数として定義できます。
function imageLinkFormatter(cellval, options, rowObject, icon, link_class, link_action) {
var img = '<span class="ui-icon ' + icon + ' icon"><span/>';
var link = '<a href="#' + link_action + '/id/' + rowObject.id + '" class="' +
link_class + '" rel="' + rowObject.id + '">' + img + '</a>';
return link;
}
追加のパラメーターを使用して、グリッドのさまざまな列のカスタムフォーマッターから関数を呼び出します。
colModal: [
{name: 'col1', formatter: function (cellvalue, options, rowObject) {
return imageLinkFormatter(cellvalue, options, rowObject,
'ui-icon-pencil', 'edit-link-class', 'Edit');
}},
{name: 'col2', formatter: function (cellvalue, options, rowObject) {
return imageLinkFormatter(cellvalue, options, rowObject,
'ui-icon-plus', 'add-link-class', 'Add');
}},
{name: 'col2', formatter: function (cellvalue, options, rowObject) {
return imageLinkFormatter(cellvalue, options, rowObject,
'ui-icon-trash', 'del-link-class', 'Delete');
}},
...
]
それはあなたが望むものですか?