use*_*961 3 javascript typeahead.js
我正在尝试使用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: [
'<p class="lang-id">{{lang_id}}</p>',
'<p class="value">{{value}}</p>'
].join(''),
engine: Hogan
});
Run Code Online (Sandbox Code Playgroud)
它工作正常,但模板设置被忽略 - 我仍然得到默认下拉列表.我究竟做错了什么?
编辑:我也尝试过:
$('input').typeahead(null, {
name: 'countries',
displayKey: 'value',
source: countries.ttAdapter(),
templates: {
empty: [
'<div class="empty-message">',
'no results found',
'</div>'
].join('\n'),
suggestion: '<p><strong>{{value}}</strong> – {{id}}</p>'
},
engine: Hogan
});
Run Code Online (Sandbox Code Playgroud)
这会引发错误:
Property 'suggestion' of object #<Object> is not a function
kas*_*ter 11
查看文档,您可以看到名称是否templates存在template- 就像您在第二个示例中所示.你遇到的问题是suggestion需要一个函数,而不是一个字符串.在自定义模板的底部示例中,您可以看到它们使用Handlebars.compile返回一个函数,该函数接受包含数据的单个参数以使用 - 来呈现模板 - 并返回生成的HTML的字符串.如果你不想使用Handlebars你可以做类似的事情(请注意,为了简单起见,我不会逃避我的例子中的数据.对于一个正确的解决方案,你应该逃避data.value并data.id确保你不引入XSS漏洞):
$('input').typeahead(null, {
name: 'countries',
displayKey: 'value',
source: countries.ttAdapter(),
templates: {
empty: [
'<div class="empty-message">',
'no results found',
'</div>'
].join('\n'),
suggestion: function(data){
return '<p><strong>' + data.value + '</strong> - ' + data.id + '</p>';
}
},
engine: Hogan
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
9087 次 |
| 最近记录: |