コンテンツにスキップ

useFuse

カテゴリ
エクスポートサイズ
445 B
パッケージ
@vueuse/integrations
最終更新日
先週

Fuse.jsを使用したコンポーザブルで、ファジー検索を簡単に実装できます。

Fuse.jsのWebサイトより

ファジー検索とは?

一般的に、ファジー検索(より正式には近似文字列マッチングとして知られています)は、与えられたパターンとほぼ等しい文字列(正確なものというよりも)を見つけるための手法です。

デモ

ロズリン・ミッチェル スコアインデックス: 0
キャスリーン・マシューズ スコアインデックス: 1
カールトン・ハレルソン スコアインデックス: 2
アレン・ムーアズ スコアインデックス: 3
ジョン・ワシントン スコアインデックス: 4
ブルック・コルトン スコアインデックス: 5
メアリー・レノルド スコアインデックス: 6
ナニー・フィールド スコアインデックス: 7
チャスティティ・マイケル スコアインデックス: 8
オークリー・ギレス スコアインデックス: 9
ジョアンナ・シェパード スコアインデックス: 10
メイベル・ウィルキー スコアインデックス: 11
ドーソン・ラウントリー スコアインデックス: 12
マンリー・ポンド スコアインデックス: 13
ルーラ・ソーヤー スコアインデックス: 14
ハドソン・ヘクスト スコアインデックス: 15
オールデン・シニア スコアインデックス: 16
トリー・ハイランド スコアインデックス: 17
コンスタンス・ジョセフス スコアインデックス: 18
ラリー・キンズリー スコアインデックス: 19
@vueuse/integrationsアドオンで利用できます。

Fuse.jsをピア依存関係としてインストールする

NPM

bash
npm install fuse.js@^7

Yarn

bash
yarn add fuse.js

使い方

ts
import { useFuse } from '@vueuse/integrations/useFuse'
import { ref } from 'vue'

const data = [
  'John Smith',
  'John Doe',
  'Jane Doe',
  'Phillip Green',
  'Peter Brown',
]

const input = ref('Jhon D')

const { results } = useFuse(input, data)

/*
 * Results:
 *
 * { "item": "John Doe", "index": 1 }
 * { "item": "John Smith", "index": 0 }
 * { "item": "Jane Doe", "index": 2 }
 *
 */

型宣言

型宣言を表示
typescript
export type FuseOptions<T> = IFuseOptions<T>
export interface UseFuseOptions<T> {
  fuseOptions?: FuseOptions<T>
  resultLimit?: number
  matchAllWhenSearchEmpty?: boolean
}
export declare function useFuse<DataItem>(
  search: MaybeRefOrGetter<string>,
  data: MaybeRefOrGetter<DataItem[]>,
  options?: MaybeRefOrGetter<UseFuseOptions<DataItem>>,
): {
  fuse: Ref<
    {
      search: <R = DataItem>(
        pattern: string | Expression,
        options?: FuseSearchOptions,
      ) => FuseResult<R>[]
      setCollection: (
        docs: readonly DataItem[],
        index?: FuseIndex<DataItem> | undefined,
      ) => void
      add: (doc: DataItem) => void
      remove: (predicate: (doc: DataItem, idx: number) => boolean) => DataItem[]
      removeAt: (idx: number) => void
      getIndex: () => FuseIndex<DataItem>
    },
    | Fuse<DataItem>
    | {
        search: <R = DataItem>(
          pattern: string | Expression,
          options?: FuseSearchOptions,
        ) => FuseResult<R>[]
        setCollection: (
          docs: readonly DataItem[],
          index?: FuseIndex<DataItem> | undefined,
        ) => void
        add: (doc: DataItem) => void
        remove: (
          predicate: (doc: DataItem, idx: number) => boolean,
        ) => DataItem[]
        removeAt: (idx: number) => void
        getIndex: () => FuseIndex<DataItem>
      }
  >
  results: ComputedRef<FuseResult<DataItem>[]>
}
export type UseFuseReturn = ReturnType<typeof useFuse>

ソース

ソースデモドキュメント

貢献者

Anthony Fu
wheat
Darryl Noakes
Anthony Fu
Doctorwu
Jessica Sachs

変更履歴

v12.0.0-beta.1 2024年11月21日
0a9ed - feat!: Vue 2 のサポートを削除、バンドルを最適化、クリーンアップ (#4349)
v11.0.0-beta.1 2024年6月12日
cb44c - feat!: fuse.js を v7 にアップグレード (#4036)
v10.0.0-beta.4 2023年4月13日
4d757 - feat(types)!: MaybeComputedRefMaybeRefOrGetter にリネーム
0a72b - feat(toValue): resolveUnreftoValue にリネーム

MITライセンスの下でリリースされています。