|
|
|
|
|
[Build]: http://img.shields.io/travis/litejs/natural-compare-lite.png
|
|
|
[Coverage]: http://img.shields.io/coveralls/litejs/natural-compare-lite.png
|
|
|
[1]: https://travis-ci.org/litejs/natural-compare-lite
|
|
|
[2]: https://coveralls.io/r/litejs/natural-compare-lite
|
|
|
[npm package]: https://npmjs.org/package/natural-compare-lite
|
|
|
[GitHub repo]: https://github.com/litejs/natural-compare-lite
|
|
|
|
|
|
|
|
|
|
|
|
@version 1.4.0
|
|
|
@date 2015-10-26
|
|
|
@stability 3 - Stable
|
|
|
|
|
|
|
|
|
Natural Compare – [![Build][]][1] [![Coverage][]][2]
|
|
|
===============
|
|
|
|
|
|
Compare strings containing a mix of letters and numbers
|
|
|
in the way a human being would in sort order.
|
|
|
This is described as a "natural ordering".
|
|
|
|
|
|
```text
|
|
|
Standard sorting: Natural order sorting:
|
|
|
img1.png img1.png
|
|
|
img10.png img2.png
|
|
|
img12.png img10.png
|
|
|
img2.png img12.png
|
|
|
```
|
|
|
|
|
|
String.naturalCompare returns a number indicating
|
|
|
whether a reference string comes before or after or is the same
|
|
|
as the given string in sort order.
|
|
|
Use it with builtin sort() function.
|
|
|
|
|
|
|
|
|
|
|
|
### Installation
|
|
|
|
|
|
- In browser
|
|
|
|
|
|
```html
|
|
|
<script src=min.natural-compare.js></script>
|
|
|
```
|
|
|
|
|
|
- In node.js: `npm install natural-compare-lite`
|
|
|
|
|
|
```javascript
|
|
|
require("natural-compare-lite")
|
|
|
```
|
|
|
|
|
|
### Usage
|
|
|
|
|
|
```javascript
|
|
|
// Simple case sensitive example
|
|
|
var a = ["z1.doc", "z10.doc", "z17.doc", "z2.doc", "z23.doc", "z3.doc"];
|
|
|
a.sort(String.naturalCompare);
|
|
|
// ["z1.doc", "z2.doc", "z3.doc", "z10.doc", "z17.doc", "z23.doc"]
|
|
|
|
|
|
// Use wrapper function for case insensitivity
|
|
|
a.sort(function(a, b){
|
|
|
return String.naturalCompare(a.toLowerCase(), b.toLowerCase());
|
|
|
})
|
|
|
|
|
|
// In most cases we want to sort an array of objects
|
|
|
var a = [ {"street":"350 5th Ave", "room":"A-1021"}
|
|
|
, {"street":"350 5th Ave", "room":"A-21046-b"} ];
|
|
|
|
|
|
// sort by street, then by room
|
|
|
a.sort(function(a, b){
|
|
|
return String.naturalCompare(a.street, b.street) || String.naturalCompare(a.room, b.room);
|
|
|
})
|
|
|
|
|
|
// When text transformation is needed (eg toLowerCase()),
|
|
|
// it is best for performance to keep
|
|
|
// transformed key in that object.
|
|
|
// There are no need to do text transformation
|
|
|
// on each comparision when sorting.
|
|
|
var a = [ {"make":"Audi", "model":"A6"}
|
|
|
, {"make":"Kia", "model":"Rio"} ];
|
|
|
|
|
|
// sort by make, then by model
|
|
|
a.map(function(car){
|
|
|
car.sort_key = (car.make + " " + car.model).toLowerCase();
|
|
|
})
|
|
|
a.sort(function(a, b){
|
|
|
return String.naturalCompare(a.sort_key, b.sort_key);
|
|
|
})
|
|
|
```
|
|
|
|
|
|
- Works well with dates in ISO format eg "Rev 2012-07-26.doc".
|
|
|
|
|
|
|
|
|
### Custom alphabet
|
|
|
|
|
|
It is possible to configure a custom alphabet
|
|
|
to achieve a desired order.
|
|
|
|
|
|
```javascript
|
|
|
// Estonian alphabet
|
|
|
String.alphabet = "ABDEFGHIJKLMNOPRSŠZŽTUVÕÄÖÜXYabdefghijklmnoprsšzžtuvõäöüxy"
|
|
|
["t", "z", "x", "õ"].sort(String.naturalCompare)
|
|
|
// ["z", "t", "õ", "x"]
|
|
|
|
|
|
// Russian alphabet
|
|
|
String.alphabet = "АБВГДЕЁЖЗИЙКЛМНОПРСТУФХЦЧШЩЪЫЬЭЮЯабвгдеёжзийклмнопрстуфхцчшщъыьэюя"
|
|
|
["Ё", "А", "Б"].sort(String.naturalCompare)
|
|
|
// ["А", "Б", "Ё"]
|
|
|
```
|
|
|
|
|
|
|
|
|
External links
|
|
|
--------------
|
|
|
|
|
|
- [GitHub repo][https://github.com/litejs/natural-compare-lite]
|
|
|
- [jsperf test](http://jsperf.com/natural-sort-2/12)
|
|
|
|
|
|
|
|
|
Licence
|
|
|
-------
|
|
|
|
|
|
Copyright (c) 2012-2015 Lauri Rooden <lauri@rooden.ee>
|
|
|
[The MIT License](http://lauri.rooden.ee/mit-license.txt)
|
|
|
|
|
|
|