useFuse
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
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>
ソース
貢献者
変更履歴
v12.0.0-beta.1
2024年11月21日v11.0.0-beta.1
2024年6月12日v10.0.0-beta.4
2023年4月13日4d757
- feat(types)!: MaybeComputedRef
を MaybeRefOrGetter
にリネーム0a72b
- feat(toValue): resolveUnref
を toValue
にリネーム