jqGrid
を使用して、JSP
とservlet
を使用してデータを表形式で表示しています。jqgridサーバーサイドのメッセージを表示する方法
EDIT
私はinsert, update, delete
のような操作が実行されるときに、サーバーからのエラーを示したいと思います。次いで(datatype: "xml")
jqgridからinserting
レコード後
JQGrid
jQuery("#list10_d").jqGrid({
height:250,
width:600,
url:'Assignment?action=Assign',
datatype: "xml",
colNames:['Sr. No.','PID', 'DATE', 'EMPID'],
colModel:[{name:'srNo',index:'srNo', width:30,sortable:false},
{name:'PID',index:'PID',width:0, sortable:true,editable:false},
{name:'DATE',index:'DATE', width:75,sortable:true,editable:true,editoptions: { dataInit: function(el) { setTimeout(function() { $(el).datepicker({dateFormat:"dd-M-yy",showButtonPanel: true,changeYear: true,changeMonth: true}).attr('readonly','readonly'); }, 200); }}},
{name:'EMPID',index:'EMPID', width:150,sortable:true,editable:true}
],
rowNum:10,
rowList:[10,20,50,100],
pager: '#pager10_d',
sortname: 'PID',
viewrecords: true,
sortorder: "asc",
},
multiselect: true,
editurl: "Assignment?action=Edit",
caption:"Assignment"
}).navGrid('#pager10_d',{edit:false,add:true,del:false,addtext:'Assign '},
{},
{modal:true,jqModal: false,closeOnEscape:true,savekey: [true,13],closeOnEscape:true, recreateForm: true,width:500,mtype:'POST', url: 'Assignment',editData:{action: 'Assign',PID: function() {return PID;}},
afterSubmit: function (response) {
alert('After Submit \n' +'statusText: '+ response.statusText);
var myInfo = '<div class="ui-state-highlight ui-corner-all">'+
'<span class="ui-icon ui-icon-info" ' +
'style="float: left; margin-right: .3em;"></span>' +
response.statusText + 'Inserted'+
'</div>',
$infoTr = $("#TblGrid_" + $.jgrid.jqID(this.id) + ">tbody>tr.tinfo"),
$infoTd = $infoTr.children("td.topinfo");
$infoTd.html(myInfo);
$infoTr.show();
// display status message to 3 sec only
setTimeout(function() {
$infoTr.slideUp("slow");
}, 5000);
return [true, "", ""]; // response should be interpreted as successful
},
errorTextFormat: function (response) {
alert('Error Text Format: \n' +'statusText: '+ response.statusText);
return '<span class="ui-icon ui-icon-alert" ' +
'style="float:left; margin-right:.3em;"></span>' +
response.statusText;},
{closeOnEscape:true, recreateForm: true,mtype: 'POST',url: 'Assignment',delData: {action: 'Delete',PID: function() {return PID;}}},
{}) ;
サーブレットコード
上記例えばif(request.getParameter("action").equalsIgnoreCase("Assign"))
{
PID = request.getParameter("PID");
String DATE= request.getParameter("DATE");
String EMPID= request.getParameter("EMPID");
String query = "insert into ASSIGN(PID,DATE,EMPID) values('"+ PID +"','"+ DATE +"','"+ EMPID"')";
boolean b = insert.InsertData(query);
if(b)
{
System.out.println("New record added successfully! : "+query);
response.setContentType("text/xml");
response.setCharacterEncoding("UTF-8");
//response.sendError(200, "success");
response.setStatus(200, "Inserted successfully");
}
else
{
System.out.println("Failed to add Record! : "+query);
response.setContentType("text/xml");
response.setCharacterEncoding("UTF-8");
//response.sendError(399, "not Inserted successfully");
response.setStatus(404, "Error while inserting");
}
}//INSERT
- 、
No message is shown
in グリッドの場合レコードがinserted successfully
error Status: 'Unauthorized'. Error code: 401
は、データベースにレコードを挿入できない場合に表示されます。
、私の質問はその:
- jqgridから
inserting
レコードの後、レコードは私がメッセージは、データが挿入されている利用者に情報を与えて表示する必要がありますどのようにして挿入されている場合。 - とどのように私は、ユーザーにメッセージを与えるべきである(私はこれのために使うべき
error code
?)Error while inserting
事前に
おかげで.....
回答ありがとうございました(そして+1)、私は今日それを試してみます。 – Bhushan
@Bhushan:ようこそ! – Oleg
あなたのコードを実装した後で私の質問が更新されました。イメージに表示されているようにフォームの上にメッセージが表示されますが、正常に挿入された場合や正常に挿入されなかった場合や'Not Found'だけが表示されますが、私はサーブレットから送られた' custom'メッセージをフォームに表示できません。サーブレットからグリッドにエラーを送信している間に間違っていますか?どんな助けも高く評価されます... – Bhushan