我正在尝试使用Typeahead.js设置自定义模板
我的代码是:
var countries = new Bloodhound({ datumTokenizer: function(d) { return Bloodhound.tokenizers.whitespace(d.value); },queryTokenizer: Bloodhound.tokenizers.whitespace, limit: 100, remote: { url: 'http://www.domain.com/json.php?action=countries&q=%QUERY' } }); countries.initialize(); $('.lang').typeahead(null, { name: 'countries', source: countries.ttAdapter(), template: [ '{{lang_id}}
', '{{value}}
' ].join(''), engine: Hogan });
它工作正常,但模板设置被忽略 - 我仍然得到默认下拉列表.我究竟做错了什么?
编辑:我也尝试过:
$('input').typeahead(null, { name: 'countries', displayKey: 'value', source: countries.ttAdapter(), templates: { empty: [ '', 'no results found', '' ].join('\n'), suggestion: '{{value}} – {{id}}
' }, engine: Hogan });
这会引发错误:
Property 'suggestion' of object #
查看文档,您可以看到名称是否templates
存在template
- 就像您在第二个示例中所示.你遇到的问题是suggestion
需要一个函数,而不是一个字符串.在自定义模板的底部示例中,您可以看到它们使用Handlebars.compile
返回一个函数,该函数接受包含数据的单个参数以使用 - 来呈现模板 - 并返回生成的HTML的字符串.如果你不想使用Handlebars
你可以做类似的事情(请注意,为了简单起见,我不会逃避我的例子中的数据.对于一个正确的解决方案,你应该逃避data.value
并data.id
确保你不引入XSS漏洞):
$('input').typeahead(null, { name: 'countries', displayKey: 'value', source: countries.ttAdapter(), templates: { empty: [ '', 'no results found', '' ].join('\n'), suggestion: function(data){ return '' + data.value + ' - ' + data.id + '
'; } }, engine: Hogan });