Store table data in browser
Store table data in browser
data:image/s3,"s3://crabby-images/2a5c5/2a5c540cdbae9b49fd6c86f126c47e471738658d" alt="kevintivoli"
Hello,
I am adding data to table using row.add
, which is working fine, but the data disappears when page is refreshed. Is there a way to store this data in cache or something until a POST
method is called ?
Thanks
This question has an accepted answers - jump to answer
This discussion has been closed.
Answers
You could use
stateSave
to store that optional data. In this example, it's showing how to store selected rows. You could modify that to store created rows, which you then re-add on table reload.Colin
Colin, Thanks for your response.
I'm very new to DataTables and JavaScript.
I already have
StateSave
enabled. I have tried your suggestionsstateSaveParams
,stateLoadParams
andinitComplete
, but couldn't get it work. Not sure where i am going wrong. I may be completely using it in incorrect order. Would you please provide and example based on my scenario.I am adding data from a product table to cart table. Both are datatables.
Here is my code. Would you please correct where i should include your suggestions ?
I'm not seeing that
stateLoadParams
in your code, so I can't comment on what you've done. Can you show me the code you're trying to get working, please. One thing to note, is it'sstateSave
- case matter.Colin
Colin,
This is what i tried. Not sure, if i am using the
stateSaveParams
,stateLoadParams
andinitComplete
in the correct place.Basically, i need to add products from products DataTable to cart DataTable and save the state of cart DataTable .
That's heading in the right direction. You need to hold onto the list of added rows, to ensure they're getting saved. This example here is doing just that. The
Add row
button is creating new rows, which are then stored in thestateSave
data.Hope that helps,
Colin
Thank you so much @colin , i followed the example you provide and it worked like a charm !! Appreciate your help.
I have one last last question. In order to clear the state of the table without refreshing the whole page. This is what i am doing, is this correct ?
For others :- Below is my code that worked based on @colin 's suggestion.
</script>
You're welcome, glad it's all working. And yep, that looks correct, but given your question, I'm guessing there's a problem? If there is, please can you update my test case to demonstrate it, that way it'll be clearer to see.
Colin
@colin , You are right, there is a weird problem.
It seems to work the first time you click on "Empty Table" and as long as you don't refresh the page.
And when you refresh the page, the "Add Row" stops working, it doesn't add any items to the table anymore.
Then, It starts working again, if you refresh the page one more time.
I have updated your test case to demonstrate it here
@colin - To precisely recreate the issue.
Add a couple of rows by clicking on "Add Row" button, then click on "Empty Table" to remove all rows from the table. Now, refresh the page and try to click on "Add Row". It stops working, until you refresh the whole page again.
If you move thedata:image/s3,"s3://crabby-images/d17bb/d17bb7415fe4788d5a2af5d02135ea43c31a738e" alt=":) :)"
state.clear()
before theclear()
then it works - I'm not entirely sure why, but if that works for you, then I'm happyColin
@colin
Unfortunalty, moving the
state.clear()
before theclear()
is not working for me. I have createed a new thread for this issue here.Would you please take a look when you have a moment. I think i am close to achieving what i am looking for. Your help is really appreciated.
isn't this issue now resolved here in the new thread you mention above?
https://datatables.net/forums/discussion/62458
and with this example:
http://live.datatables.net/fexiqido/1/edit