JQGridに画像列が必要です。フォーマッターを使用しましたが、機能しません。この解決策を教えてください。
私のコードは次のとおりです。
jQuery(document).ready(function() {
var TheGrid ;
var resp;
jQuery("#registerUsers").jqGrid({
url: 'EventsList.aspx',
datatype: "json",
colNames: ['Name', 'Company Name', 'Responsible Name', 'Date/Time', 'Id'],
colModel: [{ name: 'GuestName', index: 'GuestName', width: 150, editable: true, editoptions: {readonly: true, size: 10} },
{ name: 'CompName', index: 'CompName', width: 150, editable: false, editoptions: { readonly: true, size: 10} },
{ name: 'RespName', index: 'RespName', width: 150, editable: false, editoptions: { readonly: true, size: 10} },
{ name: 'RegisterDate', index: 'RegisterDate', width: 150, editable: false, editoptions: { readonly: true, size: 10} },
{ name: 'Register_Id', index: 'Register_Id', width: 100, align: 'left', formatter: checkboxFormatter },
],
rowNum: 10,
rowList: [10, 20, 30],
pager: jQuery('#Userpager'),
sortname: 'Register_Id',
viewrecords: true,
sortorder: "desc",
imgpath: '/scripts/themes/steel/images',
caption: "Registered Users"
});
});
jQuery("#registerUsers").jqGrid('navGrid', '#Userpager', { edit: false, add: false, del: false });
function checkboxFormatter(el, cval, opts) {
debugger;
cval = cval + ""; cval = cval.toLowerCase();
// var bchk = cval.search(/(false|0|no|off|n)/i) < 0 ? " checked=\"checked\"" : "";
var UserId = jQuery("#registerUsers").getCell(RowId, 'Register_Id');
$(el).html("<center><img src='../images/gnome-session-logout.png' width='15px' height='15px' onclick=javascript:LogOutUser(" + UserId + ");/></center>");
// <input type='checkbox' onclick=\"ajaxSave('" + opts.rowId + "', this);\" " + bchk + " value='" + cval + "' offval='no' />
}
私を助けてください
ありがとうリッツ
フォーマッタでimgタグを文字列として返すことができます。例:
function unitsInStockFormatter(cellvalue, options, rowObject) {
var cellValueInt = parseInt(cellvalue);
if (cellValueInt > 10)
return "<img src='../../Content/images/ui-flag_green.png' alt='" + cellvalue + "'title='" + cellvalue + "' />";
else if (cellValueInt > 0)
return "<img src='../../Content/images/ui-flag_blue.png' alt='" + cellvalue + "'title='" + cellvalue + "' />";
else
return "<img src='../../Content/images/ui-flag_red.png' alt='" + cellvalue + "'title='" + cellvalue + "' />";
};
ここで説明されているように: http://tpeczek.com/2009/11/jqgrid-and-aspnet-mvc-formatting.html
セルに画像を表示する手順については、 can-you-have-images-or-any-custom-html-displayed-in-jquery-grid-jqgrid-cells を参照してください。
基本的に、src要素から引用符を削除する必要があるようです。
簡単な解決策は、クエリから直接作成できます。
idresを選択します。'HTML-IMG-SRC= images/tick_ '||予約済み|| '.png'は予約済み、日付、テーブルからの日付外です。 --postgresのクエリ
Reservedは0または1であり、フィールドの「reserved」の値に応じて、画像ファイル名「tick_1.png」または「tick_0.png」に反映されます。
それが役に立てば幸い
私はこの解決策を見つけました。
スクリプトとスタイルシートを挿入してテーブルのみをページに含め、grid.phpページを含めた後、次のようにセルをフォーマットして画像を表示できます。
以下のコードをgrid.phpに配置します。
$grid->setColProperty("COLUMN NAME", array("formatter"=>"js:formatImage"));
次に、文字列変数を入力します。Java formatImage関数のスクリプトは次のようになります。
$IMAGE_FORMAT_STRING = <<<IMAGE_FORMAT_FUNCTION
function formatImage(cellValue, options, rowObject) {
var imageHtml = "";
if(cellValue){
if(cellValue.indexOf("_thumb") == -1){
imageHtml = '<div><a href="' + cellValue + '" title="" target="_blank">' + cellValue + '</a></div>';
}else{
imageHtml = '<div class="gallery"><a href="' + cellValue.replace('_thumb', '') + '" title=""><img src="' + cellValue + '" width="50" height="50" alt="" border="0"/></a></div>';
}
}
return imageHtml;
}
function unformatImage(cellValue, options, cellObject) {
return $(cellObject.html()).attr("originalValue");
}
IMAGE_FORMAT_FUNCTION;
そしてgrid-> renderGridの上に、JavaScriptコードを次のように設定します。
$grid->setJSCode($IMAGE_FORMAT_STRING);
それが誰かに役立つことを願っています!