Je suis en train de créer une table de données entièrement modifiable avec le plugin Jatable de Datquable pour le moment. Par table entièrement modifiable, je veux dire qu'un utilisateur sera en mesure de modifier, supprimer, mettre à jour, ajouter des colonnes sur la table. Sur la base des exemples, actuellement je suis en train le code javascript suivant:Jquery Datatables Table de données entièrement modifiable
function var_dump(obj) {
if(typeof obj == "object") {
return "Type: "+typeof(obj)+((obj.constructor) ? "\nConstructor: "+obj.constructor : "")+"\nValue: " + obj;
} else {
return "Type: "+typeof(obj)+"\nValue: "+obj;
}
}//end function var_dump
var oTable;
var giRedraw = false;
var giCount=11;
$(document).ready(function() {
/* Add a click handler to the rows - this could be used as a callback */
$("#example tbody").click(function(event) {
$(oTable.fnSettings().aoData).each(function(){
$(this.nTr).removeClass('row_selected');
});
$(event.target.parentNode).addClass('row_selected');
});
/* Add a click handler for the delete row */
$('#delete').click(function() {
var anSelected = fnGetSelected(oTable);
var iRow = oTable.fnGetPosition(anSelected[0]);
oTable.fnDeleteRow(iRow);
});
oTable = $('#example').dataTable({
"bProcessing": true,
"bServerSide": true,
"sAjaxSource": "lib/server_processing.php",
"fnDrawCallback": function() {
$('#example tbody td').editable('lib/editable_ajax.php', {
"callback": function(sValue, y) {
alert(sValue);
/* Redraw the table from the new data on the server */
oTable.fnDraw();
},
"height": "14px"
});
}
});
});
function fnClickAddRow() {
oTable.fnAddData([
giCount+".1",
giCount+".2",
giCount+".3",
giCount+".4",
giCount+".5", ]
);
giCount++;
}
/* Get the rows which are currently selected */
function fnGetSelected(oTableLocal)
{
var aReturn = new Array();
var aTrs = oTableLocal.fnGetNodes();
for (var i=0 ; i<aTrs.length ; i++)
{
if ($(aTrs[i]).hasClass('row_selected'))
{
aReturn.push(aTrs[i]);
}
}
return aReturn;
}
Cela fonctionne très bien dans l'interface utilisateur, mais je n'ai aucune idée sur la façon d'envoyer les informations de colonne sur le côté serveur. Ok, je peux envoyer la nouvelle valeur de la colonne au script server_ajax mais comment puis-je envoyer les autres informations relatives à la colonne comme l'identifiant unique de la colonne modifiée dans la base de données.
En fait, j'ai déjà résolu ce problème, mais j'ai oublié de fermer ce fil. Mais puisque votre réponse est raisonnable, j'approuve la vôtre. – systemsfault