我正在使用(嗯,想使用)typeahead.js 同时按品牌名称和型号名称搜索我的数据库,并显示按品牌名称分组的可选结果。我以为我可以使用一个简单的 Mustache 模板来完成此操作,但我没有任何运气。
我当前的预输入配置:
myEl.typeahead({
"name": "models-by-brand",
"valueKey": "id",
"remote": "/search/%QUERY",
"template": '{{#brands}}' +
'<h4>{{brand_name}}</h4>' +
'{{#models}}' +
'<p><a href="#" class="pick-model" data-modelid="{{id}}">{{name}}</a></p>' +
'{{/models}}' +
'{{/brands}}',
"engine": Hogan
});
从返回的 JSON /search/super
:
{
"brands": [
{
"brand_name": "Super Widgets",
"models": [
{
"id": 1,
"name": "Crazy Widget"
}
]
},
{
"brand_name": "Acme Widgets",
"models": [
{
"id": 2,
"name": "Extra Super Widget"
},
{
"id": 2,
"name": "Double Super Widget"
}
]
}
]
}
我希望预先输入的输出按品牌名称分组,并可以按型号名称选择:
超级小工具
疯狂小工具
Acme Widgets
Extra Super Widget
Double Super Widget
但显然我不能以这种方式(使用嵌套块)使用带有预输入的 Hogan 模板。Typeahead 只显示一个没有文本的结果。
我尝试使用带有遥控器的过滤器功能来格式化每个数据,但这只能让我得到所有数据的平面列表 - 我无法弄清楚如何对结果进行分组。
使用预输入模板可以实现我想要的吗?我只是错过了一些非常明显的东西吗?我可以控制远程 JSON 结果,因此如果需要,我可以更改该格式。感谢您的任何帮助。