Fuse.js:像对象一样在数组中进行模糊搜索

mar*_*ann 2 javascript search fuzzy-search web fuse.js

我想对具有扁平层次结构的对象执行模糊搜索。在 Fuse.js 的演示页面上,您必须指定要在对象中查找的键。不幸的是,我没有特定的标识符。

Fuse.js 演示:

var books = [{
  title: "Old Man's War",
  author: {
    firstName: "John",
    lastName: "Scalzi"
  }
}];
var fuse = new Fuse(books, { keys: ["title", "author.firstName"] });
Run Code Online (Sandbox Code Playgroud)

我的设置:

const data = {
  "100": "https://assets-cdn.github.com/images/icons/emoji/unicode/1f4af.png?v6",
  "1234": "https://assets-cdn.github.com/images/icons/emoji/unicode/1f522.png?v6",
  "+1": "https://assets-cdn.github.com/images/icons/emoji/unicode/1f44d.png?v6",
  "-1": "https://assets-cdn.github.com/images/icons/emoji/unicode/1f44e.png?v6"
};

const fuse = new Fuse(data, { keys: ??? });
fuse.search('+1'); // should return "https://assets-cdn.github.com/images/icons/emoji/unicode/1f44d.png?v6",
Run Code Online (Sandbox Code Playgroud)

Ger*_*api 6

您可以使用该Object.keys()函数获取动态对象的键。如果您也希望支持旧浏览器,您可以在此处(在 Polyfill 下)找到一个 polyfill 实现。

然后,你可以提供保险丝,这样的按键:Object.keys(myobject)

编辑:

为了转换对象本身,您可以执行类似于 Jordan 建议的操作:

var newData = Object.keys(data).map(function(key) {
  return { id: key, link: data[key]};
}) 
Run Code Online (Sandbox Code Playgroud)

然后是键数组['id'],您应该按 id 进行搜索。


Jor*_*nev 5

首先解析你的data

const data = JSON.parse(json);
Run Code Online (Sandbox Code Playgroud)

然后是一种方法(但肯定会比第二个建议慢,因为所有键都包含在搜索中):

const fuse = new Fuse(data, { keys: data.keys() });
Run Code Online (Sandbox Code Playgroud)

或者您可以动态更改数据结构:

let structuredData = [];

for (key in data)
    structuredData.push({
        "id": key,
        "url": structuredData[key]
    });

const fuse = new Fuse(structuredData, { keys: ["id"] });
Run Code Online (Sandbox Code Playgroud)