lunr.js 像魅力一样工作,数据格式如下
[{
'id': 1,
'first_name': 'Joseph',
'last_name': 'Williams',
'email': 'jwilliams0@hud.gov',
'gender': 'Male',
'age': 94
}, {
'id': 2,
'first_name': 'Christina',
'last_name': 'Lawrence',
'email': 'clawrence1@clickbank.net',
'gender': 'Female',
'age': 67
}]
但当数据如下所示时,它不会。
[{
'id': { 'id': 614, 'value': 1 },
'first_name': { 'id': 244, 'value': 'Johnny' },
'last_name': { 'id': 724, 'value': 'Fields' },
'email': { 'id': 567, 'value': 'jfields0@barnesandnoble.com' },
'gender': { 'id': 220, 'value': 'Male' },
'age': { 'id': 745, 'value': 18 }
}, {
'id': { 'id': 204, 'value': 2 },
'first_name': { 'id': 163, 'value': 'Kathy' },
'last_name': { 'id': 991, 'value': 'Gilbert' },
'email': { 'id': 453, 'value': 'kgilbert1@over-blog.com' },
'gender': { 'id': 184, 'value': 'Female' },
'age': { 'id': 337, 'value': 50 }
}]
关于我应该如何索引数据以使其工作的任何提示。
添加到 lunr 的文档应该采用类似于您在答案第一部分中的格式的形式,如果您的数据具有其他结构,那么您将不得不将其转换为 lunr 可以理解的东西。
假设索引定义如下所示:
var idx = lunr(function () {
this.ref('id')
this.field('first_name')
this.field('last_name')
this.field('email')
this.field('gender')
this.field('age')
})
然后,在将文档添加到索引之前,您需要通过如下所示的函数对其进行映射:
var mapDocument = function (doc) {
return Object.keys(doc).reduce(function (memo, key) {
memo[key] = doc[key].value
return memo
}, {})
}
该函数有效地展平了整个文档,您可能希望限制实际从文档中提取的字段,但希望您能理解这个想法。然后,上述函数将从以下位置转换您的文档:
{
'id': { 'id': 614, 'value': 1 },
'first_name': { 'id': 244, 'value': 'Johnny' },
'last_name': { 'id': 724, 'value': 'Fields' },
'email': { 'id': 567, 'value': 'jfields0@barnesandnoble.com' },
'gender': { 'id': 220, 'value': 'Male' },
'age': { 'id': 745, 'value': 18 }
}
对于伦尔可以理解的事情:
{
'id': 1,
'first_name': 'Johnny',
'last_name': 'Fields',
'email': 'jfields0@barnesandnoble.com',
'gender': 'Male',
'age': 18
}