columns.type
Set the column type - used for filtering and sorting string processing.
Description
When operating in client-side processing mode, DataTables can process the data used for the display in each cell in a manner suitable for the action being performed. For example, HTML tags will be removed from the strings used for filter matching, while sort formatting may remove currency symbols to allow currency values to be sorted numerically. The formatting action performed to normalise the data so it can be ordered and searched depends upon the column's type.
DataTables has a number of built in types which are automatically detected:
date
- Date / time values. Note that DataTables' built in date parsing works to an ISO 8601 format with 3 separators (/
,-
and,
). Additional date format support can be added through the use of the built indatetime
renderer plus one of the Moment.js or Luxon libraries.- Sorting - sorted chronologically
- Filtering - no effect
num
- Simple number sorting.- Sorting - sorted numerically
- Filtering - no effect
num-fmt
- Numeric sorting of formatted numbers. Numbers which are formatted with thousands separators, currency symbols or a percentage indicator will be sorted numerically automatically by DataTables.- Supported built-in currency symbols are
$
,£
,€
and¥
. - Supported built-in thousands separators are
'
and,
. - Examples:
- $100,000 - sorted as
100000
- £10'000 - sorted as
10000
- 5'000 - sorted as 5000
- 40% - sorted as 40
- Sorting - sorted numerically
- Filtering - no effect
- Supported built-in currency symbols are
html-num
- As per thenum
option, but with HTML tags also in the data.- Sorting - sorted numerically
- Filtering - HTML tags removed from filtering string
html-num-fmt
- As per thenum-fmt
option, but with HTML tags also in the data.- Sorting - sorted numerically
- Filtering - HTML tags removed from filtering string
html
- Basic string processing for HTML tags- Sorting - sorted with HTML tags removed
- Filtering - HTML tags removed from filtering string
string
- Fall back type if the data in the column does not match the requirements for the other data types (above).- Sorting - no effect
- Filtering - no effect
It is expected that the above options will cover the majority of data types used with DataTables, however, data is flexible and comes in many forms, so additional types with different effects can be added through the use of plug-ins. This provides the ability to sort almost any data format imaginable!
As an optimisation, if you know the column type in advance, you can set the value using this option, saving DataTables from running its auto detection routine.
Please note that if you are using server-side processing (serverSide
) this option has no effect since the ordering and search actions are performed by a server-side script.
Type
This option can be given in the following type(s):
Default
Auto-detected from raw data.
Examples
Set the first column's type manually with columnDefs
:
new DataTable('#myTable', {
columnDefs: [{ type: 'html', targets: 0 }]
});
Set the first column's type manually with columns
:
new DataTable('#myTable', {
columns: [{ type: 'html' }, null, null, null, null]
});
Related
The following options are directly related and may also be useful in your application development.