当前位置:  开发笔记 > 编程语言 > 正文

Typeahead.js - 忽略模板设置

如何解决《Typeahead.js-忽略模板设置》经验,为你挑选了1个好方法。

我正在尝试使用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 # is not a function



1> kastermester..:

查看文档,您可以看到名称是否templates存在template- 就像您在第二个示例中所示.你遇到的问题是suggestion需要一个函数,而不是一个字符串.在自定义模板的底部示例中,您可以看到它们使用Handlebars.compile返回一个函数,该函数接受包含数据的单个参数以使用 - 来呈现模板 - 并返回生成的HTML的字符串.如果你不想使用Handlebars你可以做类似的事情(请注意,为了简单起见,我不会逃避我的例子中的数据.对于一个正确的解决方案,你应该逃避data.valuedata.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 });

推荐阅读
mobiledu2402851323
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有