Bloodhound 远程查询有效,但没有任何建议

mdh*_*ari 5 jquery twitter-bootstrap typeahead.js bloodhound

我使用 Bloodhound 作为提前输入的建议引擎。

问题是当我在 Bloodhound 中使用远程源时。它进行查询并获取结果,但是当我搜索结果时没有返回任何内容。

更具体地说,这段代码工作得很好:

    categoryEngine = new Bloodhound({                                                                                                                                                                          
        queryTokenizer: Bloodhound.tokenizers.whitespace,                                                                                                                                                      
        datumTokenizer: Bloodhound.tokenizers.obj.whitespace('title'),                                                                                                                                         
        local: [{                                                                                                                                                                                              
            id: 1,                                                                                                                                                                                             
            title: 'Pizza'                                                                                                                                                                                     
        },                                                                                                                                                                                                     
        {                                                                                                                                                                                                      
            id: 2,                                                                                                                                                                                             
            title: 'Pasta'                                                                                                                                                                                     
        }                                                                                                                                                                                                      
        ]                                                                                                                                                                                                      
    });                                                                                                                                                                                                        
    categoryEngine.initialize();                                                                                                                                                                               
    categoryEngine.search('Pi', function(s) {                                                                                                                                                                  
        console.log('food='+JSON.stringify(s));                                                                                                                                                                
    });   
Run Code Online (Sandbox Code Playgroud)

food=[{"id":1,"title":"Pizza"}]在控制台中登录是正确的。但这是带有远程源的:

    categoryEngine = new Bloodhound({                                                                                                                                                                          
        queryTokenizer: Bloodhound.tokenizers.whitespace,                                                                                                                                                      
        datumTokenizer: Bloodhound.tokenizers.obj.whitespace('title'),                                                                                                                                         
        remote: {                                                                                                                                                                                              
           url: '/complete/category_title/%QUERY',                                                                                                                      
            wildcard: '%QUERY'                                                                                                                                                                                 
        }                                                                                                                                                                                                      
    });                                                                                                                                                                                                        
    categoryEngine.initialize();                                                                                                                                                                               
    categoryEngine.search('Pi', function(s) {                                                                                                                                                                  
        console.log('food='+JSON.stringify(s));                                                                                                                                                                
    });
Run Code Online (Sandbox Code Playgroud)

向服务器发出请求:

GET /complete/category_title/Pi HTTP/1.1
Host: XXXXX
Connection: keep-alive
Accept: application/json, text/javascript, */*; q=0.01
X-Requested-With: XMLHttpRequest
User-Agent: Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/42.0.2311.90 Safari/537.36
Referer: YYYYY
Accept-Encoding: gzip, deflate, sdch
Accept-Language: en-US,en;q=0.8,fa;q=0.6
Cookie: PHPSESSID=ZZZZZ
Run Code Online (Sandbox Code Playgroud)

并采取以下回应:

HTTP/1.1 200 OK
Host: XXXXX
Connection: close
X-Powered-By: PHP/5.6.8
Cache-Control: no-cache
Date: Sun, 10 May 2015 14:24:22 GMT
Content-Type: application/json

[{"id":13,"title":"Pizza"}]
Run Code Online (Sandbox Code Playgroud)

这似乎也是正确的,但该search方法不起作用,并且调试food=[]行在控制台中打印,因为它没有返回结果。

我正在使用这些库:

  • jQuery v1.11.2
  • jQuery 迁移 v1.2.1
  • jQuery UI v1.11.2
  • 引导程序 v3.3.1
  • 预输入 v0.11.1

Ami*_*mit 2

从表面上看,问题在于 Bloodhound.search 在第二个回调(第三个参数)(Bloodhound.search)中返回异步(远程)结果。您应该将代码更改为:

var cb = function(s) {console.log('food='+JSON.stringify(s));};
categoryEngine.search('Pi', cb, cb);
Run Code Online (Sandbox Code Playgroud)