Convert Figma logo to code with AI

algolia logoalgoliasearch-client-javascript

⚡️ A fully-featured and blazing-fast JavaScript API client to interact with Algolia.

1,329
222
1,329
44

Top Related Projects

Official Elasticsearch client library for Node.js

10,142

A modern text/numeric/geo-spatial/vector indexing library for go

ZincSearch . A lightweight alternative to elasticsearch that requires minimal resources, written in Go.

Quick Overview

Algoliasearch-client-javascript is the official JavaScript client for Algolia's search API. It provides a seamless way to integrate Algolia's powerful search capabilities into JavaScript applications, supporting both browser and Node.js environments. The library offers a user-friendly interface to interact with Algolia's search engine, enabling developers to implement fast and relevant search experiences.

Pros

  • Easy to use and well-documented API
  • Supports both browser and Node.js environments
  • Provides advanced features like faceting, highlighting, and geo-search
  • Offers TypeScript support for improved type safety

Cons

  • Requires an Algolia account and API credentials
  • May have a learning curve for complex search configurations
  • Dependency on external service might impact application architecture
  • Pricing can be a concern for high-volume searches

Code Examples

  1. Basic search:
const client = algoliasearch('YOUR_APP_ID', 'YOUR_SEARCH_API_KEY');
const index = client.initIndex('your_index_name');

index.search('query').then(({ hits }) => {
  console.log(hits);
});
  1. Search with filters:
index.search('query', {
  filters: 'category:electronics AND price < 100'
}).then(({ hits }) => {
  console.log(hits);
});
  1. Faceted search:
index.search('query', {
  facets: ['category', 'brand'],
  maxValuesPerFacet: 10
}).then(({ facets }) => {
  console.log(facets);
});

Getting Started

  1. Install the library:
npm install algoliasearch
  1. Initialize the client:
import algoliasearch from 'algoliasearch';

const client = algoliasearch('YOUR_APP_ID', 'YOUR_SEARCH_API_KEY');
const index = client.initIndex('your_index_name');
  1. Perform a search:
index.search('your query').then(({ hits }) => {
  console.log(hits);
}).catch(err => {
  console.error(err);
});

Competitor Comparisons

Official Elasticsearch client library for Node.js

Pros of elasticsearch-js

  • More comprehensive API coverage for Elasticsearch-specific features
  • Better suited for complex, enterprise-level search implementations
  • Supports both Node.js and browser environments

Cons of elasticsearch-js

  • Steeper learning curve due to more complex API
  • Requires more setup and configuration compared to algoliasearch-client-javascript
  • Less focus on ease of use for simple search implementations

Code Comparison

elasticsearch-js:

const { Client } = require('@elastic/elasticsearch')
const client = new Client({ node: 'http://localhost:9200' })

await client.search({
  index: 'my-index',
  body: { query: { match: { title: 'search' } } }
})

algoliasearch-client-javascript:

const algoliasearch = require('algoliasearch');
const client = algoliasearch('YOUR_APP_ID', 'YOUR_API_KEY');
const index = client.initIndex('your_index_name');

await index.search('search query');

The code comparison shows that elasticsearch-js requires more configuration and a more complex query structure, while algoliasearch-client-javascript offers a simpler, more streamlined approach to basic search operations. However, elasticsearch-js provides more flexibility for advanced use cases and complex queries.

10,142

A modern text/numeric/geo-spatial/vector indexing library for go

Pros of bleve

  • Open-source and self-hosted, providing full control over data and infrastructure
  • Written in Go, offering high performance and easy integration with Go applications
  • Supports multiple storage engines and custom index mapping

Cons of bleve

  • Requires more setup and maintenance compared to Algolia's managed service
  • Less extensive documentation and community support
  • May require more development effort for advanced features

Code Comparison

bleve:

index, _ := bleve.New("example.bleve", mapping)
doc := struct{
    ID   string
    Name string
}{"1", "John Doe"}
index.Index(doc.ID, doc)

algoliasearch-client-javascript:

const index = client.initIndex('contacts');
const record = { objectID: '1', name: 'John Doe' };
index.saveObject(record).wait();

Both libraries provide simple APIs for indexing documents, but bleve offers more flexibility in terms of index configuration and storage options. algoliasearch-client-javascript, on the other hand, provides a more streamlined experience with its cloud-based service.

ZincSearch . A lightweight alternative to elasticsearch that requires minimal resources, written in Go.

Pros of ZincSearch

  • Open-source and self-hosted, providing more control over data and infrastructure
  • Lightweight and easy to deploy, with a single binary distribution
  • Designed for full-text search with a focus on performance and scalability

Cons of ZincSearch

  • Less mature ecosystem and community support compared to Algolia
  • Limited advanced features and integrations out of the box
  • May require more setup and maintenance effort for complex use cases

Code Comparison

ZincSearch (Go):

index := client.NewIndex("my_index")
doc := map[string]interface{}{
    "id": "1",
    "title": "Example Document",
    "content": "This is a sample document for indexing.",
}
_, err := index.AddDocument(doc)

Algolia JavaScript Client:

const index = client.initIndex('my_index');
const record = {
  objectID: '1',
  title: 'Example Document',
  content: 'This is a sample document for indexing.',
};
index.saveObject(record).wait();

Both examples demonstrate adding a document to an index, but ZincSearch uses a more Go-idiomatic approach, while the Algolia client follows JavaScript conventions and provides a promise-based API.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

Algolia for JavaScript

The perfect starting point to integrate Algolia within your JavaScript project

NPM version NPM downloads jsDelivr Downloads License

Documentation • InstantSearch • Community Forum • Stack Overflow • Report a bug • FAQ • Support

✨ Features

  • Thin & minimal low-level HTTP client to interact with Algolia's API
  • Works both on the browser and node.js
  • UMD and ESM compatible, you can use it with any module loader
  • Built with TypeScript

💡 Getting Started

To get started, you first need to install algoliasearch (or any other available API client package). All of our clients comes with type definition, and are available for both browser and node environments.

With a package manager

yarn add algoliasearch@5.18.0
# or
npm install algoliasearch@5.18.0
# or
pnpm add algoliasearch@5.18.0

Without a package manager

Add the following JavaScript snippet to the of your website:

// for the full client
<script src="https://cdn.jsdelivr.net/npm/algoliasearch@5.18.0/dist/algoliasearch.umd.js"></script>

// for the lite client
<script src="https://cdn.jsdelivr.net/npm/algoliasearch@5.18.0/dist/lite/builds/browser.umd.js"></script>

Usage

You can now import the Algolia API client in your project and play with it.

import { algoliasearch } from 'algoliasearch';

const client = algoliasearch('YOUR_APP_ID', 'YOUR_API_KEY');

// or with the lite client
import { liteClient } from 'algoliasearch/lite';

const client = liteClient('YOUR_APP_ID', 'YOUR_API_KEY');

For full documentation, visit the Algolia JavaScript API Client.

❓ Troubleshooting

Encountering an issue? Before reaching out to support, we recommend heading to our FAQ where you will find answers for the most common issues and gotchas with the client. You can also open a GitHub issue

📄 License

The Algolia JavaScript API Client is an open-sourced software licensed under the MIT license.

NPM DownloadsLast 30 Days