A bit like Solr, but much smaller and not as bright.
A very simple search index can be created using the following:
var idx = lunr(function () {
this.field('title', { boost: 10 })
this.field('body')
})
Adding documents to be indexed is as simple as:
var doc = {
"title": "Twelfth-Night",
"body": "If music be the food of love, play on: Give me excess of it…",
"author": "William Shakespeare",
"id": 1
}
idx.add(doc)
Then searching is as simple:
idx.search("love")
This returns a list of matching documents with a score of how closely they match the search query:
[{
"ref": 1,
"score": 0.87533
}]
API documentation is available, as well as a full working example.
Lunr.js is a small, full-text search library for use in the browser. It indexes JSON documents and provides a simple search interface for retrieving documents that best match text queries.
For web applications with all their data already sitting in the client, it makes sense to be able to search that data on the client too. It saves adding extra, compacted services on the server. A local search index will be quicker, there is no network overhead, and will remain available and useable even without a network connection.
Simply include the lunr.js source file in the page that you want to use it. Lunr.js is supported in all modern browsers.
Browsers that do not support ES5 will require a JavaScript shim for Lunr to work. You can either use Augment.js, ES5-Shim or any library that patches old browsers to provide an ES5 compatible JavaScript environment.
Contributions are very welcome, to make the process as easy as possible please follow these steps:
- Open an issue detailing the bug you've found, or the feature you wish to add. Simplified working examples using something like jsFiddle make it easier to diagnose your problem.
- Add tests for your code (so I don't accidentally break it in the future)
- Don't change version numbers or make new builds as part of your changes
A JavaScript runtime is required for building the library.
Run the tests with, this will use phantomjs to run the tests:
make test
The tests can also be run in the browser by starting the test server:
make test_server
This will start a server on port 3000, the tests are then available at '/test'