Use of render() and createdCell() functions along with bubble editing in client-side processing
Use of render() and createdCell() functions along with bubble editing in client-side processing
data:image/s3,"s3://crabby-images/23dfd/23dfd72203125d0564c9f021f1ae76f5a83510ff" alt="ISYC"
Hi,
We're starting to use Editor in our tables (bubble editing). Typically, the configuration of the columns looks like this (in this case, only the columns "name" and "codename" are editable):
{
columns: [
{
data: 'timestamp',
visible: false,
orderable: false,
searchable: false
},
{
data: 'id',
orderable: false,
searchable: false,
width: "42px",
render: function ( data, type, row, meta ) {
// Some code that renders buttons/icons
},
createdCell: function (td, cellData, rowData, row, col) {
// Some code that assigns click events to the rendered buttons/icons, sometimes based on the data of the row
}
},
{
data: 'name',
},
{
data: 'codename',
},
...
],
...
}
This schema is functioning well when we use server-side processing (serverSide: true
): every time I modify one of the cells, the table is redrawn and both methods (render
and createdCell
) are called. However, if we use client-side processing, only the render function is called. How can we achieve the rendering and the click events using this approach on both server-side and client-side processing?
Thanks,
This question has an accepted answers - jump to answer
Answers
The
columns.createdCell
method is triggered only when the cell is actually created. With client-side processing, that happens only once since we reuse the cell.If you are just using
columns.createdCell
to add events, I'd suggest instead that you use a delegated event such as that shown here which will make life much easier!Allan
Thanks Allan! We'll try to use delegated events, as it works properly on both scenarios.