Preloading dropdowns with all possible (unique) options
Preloading dropdowns with all possible (unique) options
data:image/s3,"s3://crabby-images/875d8/875d80e0c5a23d6c7c198ea5d4085393425ceb74" alt="StevieDC"
I'm sorry I can't link to a test case as I am developing locally.
I would like to use Ajax datatables to display a subset of columns from my table. I would also like to have some dropdown menus above the datatable to filter on columns (more dropdowns than the number of columns being displayed).
So far I have found an example of adding dropdowns under the datatable columns but [1] I need dropdowns for other fields not being displayed and [2] the dropdowns are only being populated with what is actually displayed not all the unique options from the whole MySql table.
Is this possible please?
Thanks, Steve.
Replies
Yes its all possible. Take this example as a base to work from.
You can use
columns.visible
to hide the columns you don't want to show but want to filter.Same as above.
Use the
column-selector
of{page: 'current'}
to iterate only the columns on the page. I updated the linked example to show this:http://live.datatables.net/zuqewuwu/1/edit
Note the addition of
var api = this.api();
as the first line ininitComplete
. Also changed thecolumn().data()
loop to look like this:Change thedata:image/s3,"s3://crabby-images/d17bb/d17bb7415fe4788d5a2af5d02135ea43c31a738e" alt=":smile: :smile:"
console.log(d)
to place the options list where you like. Was too lazy to build out the inputs, etcYou can use the
draw
event to re-write the select inputs for each table draw (sorting, searching or paging) instead of usinginitComplete
which only runs once.Kevin
Thank you so much Kevin. Much appreciated.
Hi Kevin,
I didn't explain the 2nd issue very well. I need the menu to display all the values in the mysql table for that column. That is working perfectly unless I have serverSide set to true - which is what I'd prefer. In this case the dataTable is only loading the values it knows about. I guess I need load/pre-load the menu myself with all the possible values (?)
Forget about thedata:image/s3,"s3://crabby-images/d17bb/d17bb7415fe4788d5a2af5d02135ea43c31a738e" alt=":smile: :smile:"
{page: 'current'}
stuffThe recommended solution is to have the server script look for the
draw
parameter and if it equals1
, which is the initial table load, then fetch the unique options from MySql and return an extra object with the options. The second parameter of theinitComplete
function is the returned JSON. You can access theoptions
object and build your selects.Kevin
Excellent. Thanks again Kevin.data:image/s3,"s3://crabby-images/d17bb/d17bb7415fe4788d5a2af5d02135ea43c31a738e" alt=":) :)"