Skip to content

A no-frills vanilla.JS table drop-in table sorting library

Notifications You must be signed in to change notification settings

BtheGit/sortable-js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

41 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

A no-frills Vanilla.JS drop-in library for turning static tables into sortable ones.

Live Demo

To use:

First install in the terminal:

npm install sortabletables-js

Then in your file:

import sortablejs from 'sortabletables-js';

sortablejs();

or

const sortablejs = require('sortabletables-js').default;

sortablejs();

NOTE: This library uses Array.from and Object.assign. These require polyfills for ie11 compatibility.

Table Attribute Options

Fixed Columns (data-fixed)

If you do not want a column to be sortable (i.e. not be given the data-sorted attribute or an event listener to handle interaction), add the attribute 'data-fixed' to the header cell.

Note: This does not freeze the position of the column cells, they will still reorder when other columns are sorted.

Presorting (data-sortable-presort)

If you want to have a table sort on initialization, add the attribute 'data-sortable-presort' to the header cell of the column you wish to presort the table by.

NOTE: The presort only sorts according to the first column with the attribute it finds. If you have added the presort attribute multiply times, it will ignore all but the first.

Column Data Type (data-sortable-type="xxx")

To specify a specific type for a column, use the attribute 'data-sortable-type="name"', where 'name' is the name of the type you wish to specify.

The type is used during sorting to determine which sort function to apply to the column. In order to utilize custom sort functions, you need to pass in the function during initialization and specify its key in this attribute, i.e. 'data-sortable-type="customSortFunctionKey"'. (See Custom Data Types and Sort Functions below for more information.)

Initialization Options

Table Selector (options.tableSelector)

Default table selector: 'table[data-sortable]'

By default, to indicate a table should be sortable, add the attribute 'data-sortable' to the table container element. Multiple tables on a single page can be sortable.

An optional string representing a custom selector can be passed to the library when initialized. By default the library uses 'table[data-sortable]'.

sortablejs({ tableSelector: '.custom-sortable-table-classname' });

Column Header Cells and Body Rows Selectors(options.columnHeadersSelector & options.bodyRowsSelector)

Default header cells selector: 'thead th'

Default body rows selector: 'tbody tr'

Use these options to override the default targets for header cells and body rows. This is mostly useful for cases where you may be creating a table using atypical HTML elements.

sortablejs({
    tableSelector: '.fake-table',
    columnHeadersSelector: '.fake-table-header > div',
    bodyRowsSelector: '.fake-table-row',
})

Custom Data Types and Sort Functions (options.customSortFunctions)

Currently, the library uses one generic sort function. It is possible to pass in custom sort functions. To do so you should do two things:

  1. Add the data-sortable-type attribute to the header cell of the column you wish to sort with a corresponding value matching the name of your custom sort function.

    <th data-sortable-type="color">Colors</th>
  2. Add a corresponding sort function to the cusomSortFunctions object in the settings object.

    sortablejs({
      tableSelector: 'table[data-sortable]',
      customSortFunctions: {
        color: () => {},
      }
    })
  • IMPORTANT: If you pass a sort function that does not have a matching data-sortable-type on the table, the library will default to using the generic sort function

  • DOUBLE DOG IMPORTANT: Do not use a custom sort function with the name __default__ unless you're the sort of person who likes starting off their JS programs with Object.prototype.hasOwnProperty = () => false;

Custom Sort Functions (How to write one)

Your custom sort function will be called with three arguments: the current value, the next value, and a boolean representing whether or not the current sort direction is up.

Your sort function should return an integer value representing the desired order of the current and next values. In the case of equality (returning 0), their order will be preserved.

A basic example of a numerical sort function:

const number = (a, b, sortUp) => {
  return sortUp ? a - b : b - a;
}

Table requirements:

Tables do not need to use table specific elements if a custom override is provided (see second example below)

The classic table structure works out of the box with the library's default selectors:

<table data-sortable>
  <thead>
    <tr>
      <th></th>
      <th></th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td></td>
      <td></td>
    </tr>
    <tr>
      <td></td>
      <td></td>
    </tr>
  </tbody>
  <tfoot>
    <td></td>
  </tfoot>
</table>
sortablejs()

Using custom selectors we are able to turn simple divs into a sortable table as well:

<div class="fake-table">
  <div class="fake-table-header">
    <div></div>
    <div></div>
    <div></div>
  </div>
  <div class="fake-table-row">
    <div></div>
    <div></div>
    <div></div>
  </div>
  <div class="fake-table-row">
    <div></div>
    <div></div>
    <div></div>
  </div>
</div>
sortablejs({
    tableSelector: '.fake-table',
    columnHeadersSelector: '.fake-table-header > div',
    bodyRowsSelector: '.fake-table-row',
})

IMPORTANT:

The number of cells in each row in the body (row.children) must be equal to the number of cells in the header row or an error will be thrown.

About

A no-frills vanilla.JS table drop-in table sorting library

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published