Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
synchronous-autocomplete
Advanced tools
Fast, simple autocompletion. Supports autocompletion and Levenshtein-based fuzzy search. Uses precomputed indexes to be fast.
npm install synchronous-autocomplete
Let's build a simple search for our fruit stand. We assign a weight
property to each of them because some are bought more often and we want to push their ranking in the search results.
const items = [ {
id: 'apple',
name: 'Juicy sour Apple.',
weight: 3
}, {
id: 'banana',
name: 'Sweet juicy Banana!',
weight: 2
}, {
id: 'pomegranate',
name: 'Sour Pomegranate',
weight: 5
} ]
Let's understand the terminology used by this tool:
Hey There!
, you may process its name into the tokens hey
& there
.ther
(from the search query Hey There!
) partially matches the token there
.In order to be as fast an disk-space-efficient as possible, synchronous-autocomplete
requires four indexes to be prebuilt from the list of items. They look like this for our example:
const tokens = {
juicy: ['apple', 'banana'],
sour: ['apple', 'pomegranate'],
apple: ['apple'],
sweet: ['banana'],
banana: ['banana'],
pomegranate: ['pomegranate']
}
const weights = {
apple: 3,
banana: 2,
pomegranate: 5
}
const nrOfTokens = {
apple: 3,
banana: 3,
pomegranate: 2
}
const scores = {
juicy: 2 / 3, // 2 out of 3 items
sour: 2 / 3, // 2 out of 3 items
apple: 1 / 3, // 1 out of 3 items
sweet: 1 / 3, // 1 out of 3 items
banana: 1 / 3, // 1 out of 3 items
pomegranate: 1 / 3 // 1 out of 3 items
}
See the example code for more details on how to build them.
Now, we can query our index:
autocomplete('bana')
// [ {
// id: 'banana',
// relevance: 0.66667,
// score: 0.83995
// } ]
autocomplete('sour')
// [ {
// id: 'pomegranate',
// relevance: 1.83333,
// score: 3.13496
// }, {
// id: 'apple',
// relevance: 1.22222,
// score: 1.76275
// } ]
autocomplete('aplle', 3, true) // note the typo
// [ {
// id: 'apple',
// relevance: 0.22222,
// score: 0.3205
// } ]
const autocomplete = create(tokens, scores, weights, nrOfTokens, tokenize)
autocomplete(query, limit = 6, fuzzy = false, completion = true)
tokens
must be an object with an array of item IDs per token.
scores
must be an object with a token score per token.
weights
must be an object with an item weight per item ID.
nrOfTokens
must be an object with the number of tokens per item ID.
tokenize
must be a function that, given a search query, returns an array of fragments.
If you have a question or have difficulties using synchronous-autocomplete
, please double-check your code and setup first. If you think you have found a bug or want to propose a feature, refer to the issues page.
FAQs
Fast, simple autocompletion.
The npm package synchronous-autocomplete receives a total of 60,430 weekly downloads. As such, synchronous-autocomplete popularity was classified as popular.
We found that synchronous-autocomplete demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.