npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

spelling

v2.0.2

Published

A spelling checker that provides words suggestions, and the facility to search for words with a specific prefix.

Downloads

2,526

Readme

spelling Build Status npm version

A spelling checker that provides words suggestions, and the facility to search for words with a specific prefix.

Install

$ npm install --save spelling

Usage

var spelling = require('./'),
    dictionary = require('./dictionaries/en_US.js');

var dict = new spelling(dictionary);

console.log(dict.lookup('yes'));
//{ found: true, word: 'yes', rank: 5398 }

console.log(dict.lookup('hei'));
/*
{ found: false,
  word: 'hei',
  suggestions:
   [ { found: true, word: 'he', rank: 38410 },
     { found: true, word: 'her', rank: 14182 },
     { found: true, word: 'hey', rank: 529 },
     { found: true, word: 'hi', rank: 398 },
     { found: true, word: 'heir', rank: 76 },
     { found: true, word: 'hen', rank: 34 },
     { found: true, word: 'hep', rank: 31 },
     { found: true, word: 'hem', rank: 21 },
     { found: true, word: 'hew', rank: 12 },
     { found: true, word: 'hex', rank: 9 } ] }
*/

console.log(dict.lookup('hey'));
//{ found: true, word: 'hey', rank: 529 }

console.log(dict.lookup('yellows'));
/*
{ found: false,
  word: 'yellows',
  suggestions:
   [ { found: true, word: 'yellow', rank: 380 },
     { found: true, word: 'yellowy', rank: 2 },
     { found: true, word: 'fellow', rank: 551 },
     { found: true, word: 'bellow', rank: 36 },
     { found: true, word: 'mellow', rank: 32 } ] }
*/

console.log(dict.lookup('colleage', {suggest: false}));
//{ found: false, word: 'colleage' }

console.log(dict.search('manu'));
/*
[ { word: 'manual', rank: 395 },
  { word: 'manure', rank: 19 },
  { word: 'manumit', rank: 2 },
  { word: 'manuel', rank: 1 },
  { word: 'manuela', rank: 1 } ]
*/

console.log(dict.search('manu', {depth: 8}));
/*
[ { word: 'manuscript', rank: 752 },
  { word: 'manual', rank: 395 },
  { word: 'manufacturer', rank: 211 },
  { word: 'manufacture', rank: 82 },
  { word: 'manure', rank: 19 },
  { word: 'manumit', rank: 2 },
  { word: 'manumission', rank: 2 },
  { word: 'manumitted', rank: 2 },
  { word: 'manumitting', rank: 2 },
  { word: 'manuela', rank: 1 },
  { word: 'manuel', rank: 1 } ]
*/

Custom Dictionaries

If you'd prefer to receive suggestions on people or place names (for which there is no apparent "rank"), you can simply supply an array of those names.

var spelling = require('./');

var dict = new spelling(['wilkes-barre', 'philadelphia']);

console.log(dict.lookup('wilkes barre'));
//{ found: false, word: 'wilkes-barre', rank: 1 }

Otherwise, the dictionary format is one big string of pairs, space delimited: word1 rank1 word2 rank2 [...] where the ranks are integers.

API

.lookup(word, [opts])

Perform dictionary lookup for the given word/words.

Parameters

{String|Array} word

The word/words array on which perform dictionary lookup.

{Object} [opts]

opts is an optional object contains options to alter the lookup behavior.

options

{boolean} suggest, default true

suggest specifies whether to give suggestions if the lookup failed to find the word in the dictionary.

Example

console.log(dict.lookup('yes'));
//{ found: true, word: 'yes', rank: 5398 }

console.log(dict.lookup('hei'));
/*
{ found: false,
  word: 'hei',
  suggestions:
   [ { found: true, word: 'he', rank: 38410 },
     { found: true, word: 'her', rank: 14182 },
     { found: true, word: 'hey', rank: 529 },
     { found: true, word: 'hi', rank: 398 },
     { found: true, word: 'heir', rank: 76 },
     { found: true, word: 'hen', rank: 34 },
     { found: true, word: 'hep', rank: 31 },
     { found: true, word: 'hem', rank: 21 },
     { found: true, word: 'hew', rank: 12 },
     { found: true, word: 'hex', rank: 9 } ] }
*/
console.log(dict.lookup('hei’, {suggest: false}));
/*
{ found: false, word: 'hei'}
*/

.search(prefix, [opts]);

Perform dictionary search for words that start with the supplied prefix, the search depth can be specified to limit the search result.

Parameters

{String} prefix

The search prefix.

{Object} [opts]

opts is an optional object contains options to alter the search behavior.

options

{Number} depth ,default is 3.

the search depth which specify how deep the search is inside the dictionary tree, in another word, how many extra letters the result words have than the prefix.

Example

 dict.search('man', {depth: 2});
[ { word: 'many', rank: 12758 },
  { word: 'man', rank: 3913 },
  { word: 'mania', rank: 66 },
  { word: 'manic', rank: 61 },
  { word: 'manly', rank: 36 },
  { word: 'manor', rank: 31 },
  { word: 'mane', rank: 14 },
  { word: 'mango', rank: 12 },
  { word: 'manna', rank: 9 },
  { word: 'manse', rank: 8 },
  { word: 'mange', rank: 7 },
  { word: 'mangy', rank: 6 },
  { word: 'manta', rank: 4 },
  { word: 'manky', rank: 4 },
  { word: 'mani', rank: 1 },
  { word: 'manet', rank: 1 },
  { word: 'manx', rank: 1 },
  { word: 'mandy', rank: 1 },
  { word: 'mann', rank: 1 },
  { word: 'man\'s', rank: 1 } ]

.insert(word, [rank])

Insert a new word into the dictionary, optionally specify the word’s rank

Parameters

{String} word

The word to be added into the dictionary.

{Number} [rank]

the word’s rank. The rank affects the suggestion and the search where words with higher ranks appear first. In case the rank is not supplied, the default rank is 1, if the word is not already in the dictionary, or increment the current word’s rank by 1 if the word is already added.

.remove(word)

Remove word from the dictionary.

Parameters

{String} word

The word to be removed from the dictionary.

Authors

spelling was written by Ahmed AlSahaf but is now maintained here.