Child row vs colvis
Child row vs colvis
data:image/s3,"s3://crabby-images/9fde9/9fde9605e285c62ab9957aa2d6ea7c94ae6ee19e" alt="nwicki"
I am using the 'colvis' button in my setup in combination with child rows.
I got the ideas on how to do that from https://datatables.net/examples/api/row_details.html and https://datatables.net/extensions/buttons/built-in.
I built a showcase for my problem on https://jsfiddle.net/L7xpkz3u/2/.
If you click on the "closed" cell, a child row should open up. By clicking on it again it should disappear. Now, if you were to use the "Column Visibility" button on top of the table, and click on a name of a column the column disappears where the content resides beside the table which does not happen if the child row was not activated during the session.
Does anyone know how to solve this problem?
This question has an accepted answers - jump to answer
Answers
A little update to my previous problem. It still persists, but a second problem occurs if you remove columns with the "colvis" button from the beginning of the table after having invoked the child rows.
So, if you activate the first child row, then remove the column "name" and immediately try to add it, we get the following exception:
Uncaught DOMException: Failed to execute 'insertBefore' on 'Node': The node before which the new node is to be inserted is not a child of this node.
I assume this is related to the previous problem stated and hope I can find a solution which solves both.
Seems the problem is the result of this statement:
tr[0].innerHTML = tr[0].innerHTML.replace('open', 'closed');
Commenting it out seems to resolve the issue. I updated the test case to use
cell().data()
to update the column withopen
/closed
. Note I also changed the default column being sorted so the update doesn't affect sorting.Kevin
Hmm, I appreciate your effort. But I do not know what test case you are talking about. I cannot see any difference in https://jsfiddle.net/L7xpkz3u/2/ . Also, when using
cell().data()
I get the data inside the child row and no possibility to update the contents of the header row. Am I missing anything?Oh, I am sorry. I again tried it with your approach and it seems I messed it up before. It works now. Thank you very much.
I now finished implementing it. Since I couldn't post the original code, I made some mistakes in the showcase which is why the answer was correct for the showcase, but not for the actual case I am using.
Nonetheless, the answer helped me find the bug and how to solve it which is why I am posting an adjusted showcase below which more accurately resembles the actual code I am working on and hopefully can help someone.
https://jsfiddle.net/5o7twgec/3/