sotable

Make any HTML table sortable

See it in action

See the Pen Accessible sorted HTML table by Ulf Schneider (@ulfschneider) on CodePen.

Usage

Download sotable-min.js from GitHub and put that file into the <head> section of your HTML page.

<script src="sotable-min.js"></script>
<script>
addEventListener('load', () => sotable()); //activate sotable functionality on load
</script>

To experiment and dive deeper, it´s best to clone the entire repository and investigate the index.html, which serves as an example. Sotable is also available as a npm package.

npm i sotable
const sotable = require('sotable');
sotable.run();

Function

Sotable will query all tables on a web page and turn each table with <th> elements in the first table row into a sortable table. An explanation of the sort behavior will be added to the table <caption>. If the table doesn´t have a caption, it will be created.

Settings

Sotable can run without any configuration, like in the example above. Nevertheless sotable can be called with a settings object.

<script src="sotable-min.js"></script>
<script>
//call sotable with a settings object
//the shown values are the default values
addEventListener('load', () => sotable({
indicatorAsc: 'ᐃ',
indicatorDsc: 'ᐁ',
sortHint: 'Sort the table by clicking on a column heading.',
restoreHint: 'Restore the original order by clicking <button>Restore Order</button>.',
whiteList: '',
blackList: ''
})); //activate sotable functionalty on load
</script>

Explanation of the settings:

indicatorAsc
A symbol to indicate that a table column is sorted in ascending order.
indicatorDsc
A symbol to indicate that a table column is sorted in descending order.
sortHint
The text to add to the table caption to inform the user how to sort the table.
restoreHint
The text to add to the table caption to inform the user how to revert sorting to the initial state. The <button> element will be injected with functionality to revert the sorting.
whiteList
A selector pattern[1], separated by comma, to select only those tables for sorting that fall into the whitelist query. The selector .soso is available, even without adding it to the whiteList.
blackList
A selector pattern, separated by comma, to not select those tables for sorting that fall into the whitelist query. blackList has higher priority than whiteList. The selector .noso is available, even without adding it to the blackList.

Accessibility

Many design decisions for proper accessibility of sotable stem from Sortable table columns by Adrian Roselli[2]. Among those are:

Inspiration for the sorting algorithm comes from JavaScript Sort HTML Table[4].


  1. Locating DOM elements using selectors ↩︎

  2. Adrian Roselli: Sortable table columns ↩︎

  3. Generally, use buttons for performing an action on the site and use links for sending the user somewhere. Source: Six ways to make your site more accessible ↩︎

  4. DelftStack: JavaScript Sort HTML Table ↩︎