Package Exports
- tablesorter
- tablesorter/dist/js/jquery.tablesorter
- tablesorter/dist/js/widgets/widget-resizable.min.js
- tablesorter/dist/js/widgets/widget-uitheme.min.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (tablesorter) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
tablesorter (FORK) is a jQuery plugin for turning a standard HTML table with THEAD and TBODY tags into a sortable table without page refreshes. tablesorter can successfully parse and sort many types of data including linked data in a cell. This forked version adds lots of new enhancements including: alphanumeric sorting, pager callback functons, multiple widgets providing column styling, ui theme application, sticky headers, column filters and resizer, as well as extended documentation with a lot more demos.
Notice!
- Because of the change to the internal cache, the tablesorter v2.16+ core, filter widget and pager (both plugin & widget) will only work with the same version or newer files.
Documentation
- See the full documentation.
- All of the original document pages have been included.
- Information from my blog post on undocumented options and lots of new demos have also been included.
- Change log moved from included text file into the wiki documentation.
Demos
- Basic alpha-numeric sort Demo.
- Links to demo pages can be found within the main documentation.
- More demos & playgrounds - updated in the wiki pages.
Features
- Multi-column alphanumeric sorting and filtering.
- Multi-tbody sorting - see the options table on the main document page.
- Supports Bootstrap v2 and 3
- Parsers for sorting text, alphanumeric text, URIs, integers, currency, floats, IP addresses, dates (ISO, long and short formats) & time. Add your own easily.
- Inline editing - see demo
- Support for ROWSPAN and COLSPAN on TH elements.
- Support secondary "hidden" sorting (e.g., maintain alphabetical sort when sorting on other criteria).
- Extensibility via widget system.
- Cross-browser: IE 6.0+, FF 2+, Safari 2.0+, Opera 9.0+, Chrome 5.0+.
- Small code size, starting at 25K minified
- Works with jQuery 1.2.6+ (jQuery 1.4.1+ needed with some widgets).
- Works with jQuery 1.9+ ($.browser.msie was removed; needed in the original version).
Licensing
- Copyright (c) 2007 Christian Bach.
- Original examples and docs at: http://tablesorter.com.
- Dual licensed under the MIT and GPL licenses.
Download
- Get all files
- Use bower:
bower install jquery.tablesorter - Use node.js:
npm install tablesorter - CDNJS: https://cdnjs.com/libraries/jquery.tablesorter
Related Projects
- Plugin for Rails. Maintained by themilkman.
- Bootsole (OOP templating engine using tablesorter) by alexweissman.
Contributing
If you would like to contribute, please...
- Fork.
- Make changes in a branch & add unit tests.
- Run
grunt test(if qunit fails, run it again - it's fickle). - Create a pull request.
Special Thanks
- Big shout-out to Nick Craver for getting rid of the
eval()function that was previously needed for multi-column sorting. - Big thanks to thezoggy for helping with code, themes and providing valuable feedback.
- Big thanks to ThsSin- for taking over for a while and also providing valuable feedback.
- Thanks to prijutme4ty for numerous contributions!
- Also extra thanks to christhomas and Lynesth for help with code.
- And, of course thanks to everyone else that has contributed, and continues to contribute to this forked project!
Questions?
- Check the FAQ page.
- Search the main documentation (click the menu button in the upper left corner).
- Search the issues to see if the question or problem has been brought up before, and hopefully resolved.
- If someone is available, ask your question in the
#tablesorterIRC channel at freenode.net. - Ask your question at Stackoverflow using a tablesorter tag.
- Please don't open a new issue unless it really is an issue with the plugin, or a feature request. Thanks!
Recent Changes
View the complete change log here.
Version 2.23.0 (8/17/2015)
- Core:
- Prevent
addRowserror. See issue #979. - Make all updating methods public
- Call a function instead of triggering an event on the table. Changes include:
$.tablesorter.addRows- called byaddRowsmethod.$.tablesorter.appendCache- renamed fromappendToTable; appends cache to DOM, called byappendCachemethod.$.tablesorter.isEmptyObject- clone of$.isEmptyObject(jQuery v1.4).$.tablesorter.sortOn- called bysortOnmethod.$.tablesorter.sortReset- called bysortResetmethod.$.tablesorter.updateAll- called byupdateAllmethod.$.tablesorter.updateCache- called byupdateCachemethod.$.tablesorter.updateCell- called byupdateCellmethod.$.tablesorter.update- called byupdateandupdateRowsmethod.
- Call a function instead of triggering an event on the table. Changes include:
addRowsnow accepts a row string if only one tbody exists in the table.- The one tbody does not include information only tbodies (which have a class name from
cssInfoBlock). - Previously, you had to make a jQuery object, append it to the table, then pass a reference containing the new rows.
- This method doesn't work if a table has multiple tbodies, because the plugin doesn't know where you want to add the rows.
- Also, updated the debug message for this method.
- The one tbody does not include information only tbodies (which have a class name from
- Use header cells instead of references to prevent IE8 error. Fixes issue #987.
- Fix above header cell targetting causing a javascript error in jQuery v1.2.6. Fixes issue #995.
- Add
updateHeadersmethod- Triggered event & public api function.
$.tablesorter.updateHeaders- called byupdateHeadersmethod.- Fixes issue #989.
- Prevent
- Docs:
- Update jQuery UI theme switcher URLs.
- ColumnSelector:
- Modify
refreshColumnSelectormethod so it also updates the contents of the container in case of changes to the header text, column priorities, etc. - See examples of these changes in the column selector methods section.
- Fixes issue #985.
- Modify
- Editable:
- Filter:
- Fix js error caused when limiting search columns - external "any" filter targeting specific columns; see Stackoverflow.
- Pager:
- Widget only: No more javascript error in widget ajax error message.
- Addon only: replace use of
$.isEmptyObjectwhich was not available in jQuery v1.2.6. - Change enable, disable & destroy trigger methods.
- Previously, these methods had to include a
.pagernamespace:enable.pager,disable.pager&destroy.pager. - These methods stopped working when unique pager namespaces were added.
- New trigger methods are named as follows:
enablePager,disablePager&destroyPager. - Fixes issue #980.
- Previously, these methods had to include a
- Unbind pager controls on destroy. Fixes issue #981.
- Add
ajaxErrorcallback function. Fixes issue #992.
- Parsers:
- parser-input-select: fix javascript error when no rows returned.
- Misc & Testing
- Miscellaneous cleanup of testing code.
- Add empty
ignoreentry to bower.json. Fixes issue #991. - Fix license in package.json to match the new spdx license expression syntax.
Version 2.22.5 (7/28/2015)
- Overall:
- Set JSHint "undef" & "unused" options. Fixed issues.
- The math widget was throwing a javascript error after missing a changed variable name & JSHint wasn't catching it, until now.
Version 2.22.4 (7/28/2015)
- Overall
- update debug logging.
consoleis now called directly & includes grouping, tables, warning & errors.
- update debug logging.
- Core
- Replace
tbodyplaceholder use of a<span>with a<colgroup>. Attempt to resolve IE error reported in issue #938. - Fix
$.tablesorter.hasWidgeterror introduced when fixing jscs issues. - Fix
$.tablesorter.isProcessingerror introduced when fixing jscs issues. - Update
isValueInArrayfunction to prevent js errors with invalid input.
- Replace
- Docs
- Remove duplicate section in math widget docs.
- Add resizable widget note about leaving
widthFixedset tofalse. See issue #958. - Update to use jQuery v1.11.3.
- Change deprecated window load function.
- Improve two-digit year parser demo.
- Minor updates.
- Filter
- Prevent invalid RegExp errors which occur while typing in an incomplete query.
- Math
- Ignored rows are now properly ignored in columns. Fixes issue #976.
- Output
- Add
output_formatContentcallback - see Stackoverflow. - Make compatible with the scroller widget when it hides columns. See pull #970, thanks VictorT83!
- Add
- Pager
- Bind using unique event namespace. See issue #961.
- Scroller
- Prevent error on destroy when not applied. See issue #965.
- Fix js error in old IE.
- Delay resize after updateAll.
- Include
sortEndin fixed column updates. See issue #977.
- Sort2Hash
- This widget updates the location hash based on the table sort, and sets the table sort on initialization. demo.
- A user can share a link with others and have the table in the same sorted order.
- The hash can be set to use header text and any text to indicate an ascending or descending sort.
- Add text & saveSort override options. Fixes issue #962.
- Other minor revisions.
- Parsers
- Checkbox in multiple columns now toggles the row class correctly.
- Grunt build: Add jscs checking & fix reported style issues.
- Testing
- Update QUnit to 1.18.0.
- Add
removeWidgettest. - Add
isValueInArraytests. - Add
isProcessingtests.
- Extras - dropping support for quicksearch plugin.