Can we render a javascript or jquery html object in 'columns.render' function?
Can we render a javascript or jquery html object in 'columns.render' function?
 ravikavya01            
            
                Posts: 2Questions: 1Answers: 0
ravikavya01            
            
                Posts: 2Questions: 1Answers: 0            
            Hi There,
I am running into a problem. I just want to add a button on each row and I have achieved it by using below code
Codepen url: https://codepen.io/ravi-shukla/pen/GbZXzj?editors=0010
$('#example').DataTable({
data: data,
 "columns": [           
   { "data": "name" },
   { 
     "data": "name",
     "render": function ( data, type, row, meta ) {
       return '<span>'+data+'</span>';
     }
   }
 ],
});
But i just want to render a javascript object like below:
$('#example').DataTable({
   data: data,
   "columns": [           
     { "data": "name" },
     { 
       "data": "name",
       "render": function ( data, type, row, meta ) {
          return $('span');
       }
     }
   ],
});
is it possible?
Edited by Colin - Syntax highlighting. Details on how to highlight code using markdown can be found in this guide.
This discussion has been closed.
            
Answers
Here are two examples of placing buttons in each row:
Using
columns.render:http://live.datatables.net/qemodapi/1/edit
Using
defaultContent:http://live.datatables.net/xijecupo/1/edit
Kevin
Hi Kevin,
Thanks for your reply,
Actually, I am using angular and whatever I want to achieve can possible with the appending JQuery or JavaScript object.
Thanks
I'm facing this problem too with vue.
Any one found a workaround for appending object-elements in render() ?
Currently no -
column.rendercannot return a DOM element. It but return a string or a number.Allan
Hi! In case it helps someone, you can do something like that to render a DOM component in column.render:
I also need to have "column.render" accept a DOM Element, which is a JavaScript object, rather than a simple value or HTML. The "outerHTML" idea does not work for me because the system creating the element tracks and works with the element, so the original element, not a clone, is needed.
@I_AM_AL_X Can you use
createdRoworcolumns.createdCellfor what you need? IF this doesn't help please provide more details of what you are trying to do.Kevin