views:

639

answers:

2

i have tested this and the reason i asked the question is that it seems to be doing different things for different tables.

i couldn't find any documentation on if this is configurable or not. I would have thought it would do the bottom but i have a few examples where i see it adding rows at the top or even in the middle sometimes. it seems quite random

any ideas ??

+4  A: 

I have looked at the source code and fnAddData calls the internal method _fnAddData, which adds one row and if successful, returns its index in the table. _fnAddData adds the new row at the bottom (the index of the new row equals the number of the rows in the table).

However, fnAddData has an optional parameter to redraw the table taking into account the various features which are enabled. This parameter defaults to true and this is what probably causes the 'random' behavior.

kgiannakakis
+2  A: 

Browsing through the source of Datatable, as explained by kgiannakaki. The method will append all new data rows to the end of the table as it should.

The reason for the "random" behavior, is as each time a new row is added the method will perform a "redraw" of the entire table unless otherwise specified. When this does so the table is run through multiple features such as filtering/sorting etc etc ... and completely rewritten to the page. Essentially I am going to guess you are adding random bits of data into new rows which may be creating the "random" effect, whenever a new row is added.

You can easily disable table redrawing by adding a second parameter in the fnAddData call which needs to be set to false.

$(this).fnAddData(data, false);

If this issue still persists I would file a bug for this issue, as their is no other reason for this behavior.

nwhiting