Używam jqGrid
do wyświetlania danych w formacie tabelarycznym, przy użyciu JSP
i servlet
.jqgrid, jak wyświetlać komunikaty po stronie serwera
EDIT
chcę pokazać błędy z serwera, gdy operacje takie jak insert, update, delete
są wykonywane. (datatype: "xml")
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;}}},
{}) ;
kod serwletu
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
w powyższym przykładzie
- po
inserting
płyty z jqGrid, następnieNo message is shown
w sieci, jeśli rekord jest error Status: 'Unauthorized'. Error code: 401
jest wyświetlany, jeśli serwlet nie może wstawić rekordu do bazy danych.
moje pytanie jest, że:
- po
inserting
rekordu z jqGrid, czy rekord jest wstawiany potem jak mam pokazać wiadomość podając informację użytkownikowi, że dane jest włożona. - i jak mam dać wiadomość do użytkownika, który
Error while inserting
(coerror code
należy użyć do tego?)
góry dzięki .....
dzięki za odpowiedź (i +1), spróbuję tego już dziś. – Bhushan
@Bhushan: Nie ma za co! – Oleg
Mam zaktualizowane moje pytanie, po zaimplementowaniu twojego kodu, teraz wiadomości są pokazane na górze formularza, jak pokazano na obrazku, ale pokazany jest tylko kod statusu, tak jak w przypadku wstawienia z powodzeniem pokazane jest tylko 'OK', a gdy nie udało się wstawić wtedy wyświetlane jest tylko 'Not Found', ale nie mogę wyświetlić komunikatu' custom' wysłanego przez serwlet w formularzu. Czy robię błąd podczas wysyłania błędu z serwletu do siatki? każda pomoc zostanie doceniona ... – Bhushan