我正在尝试使用 Elasticsearch、angularJS 和 bootstrap 实现自动完成功能。
我受到这个解决方案的启发: autocomplete/typeahead angularjs bootstrap on elasticsearch
这是我的角度代码:
angular.module('cineAngularApp')
.service('client', function (esFactory) {
return esFactory({
host: 'localhost:9200',
apiVersion: '2.2',
log: 'trace'
});
});
angular.module('cineAngularApp')
.controller('AutocompleteCtrl', function ($scope,client) {
$scope.getResult = function(val){
return client.search({
index: 'autocomplete_test',
fields: 'city',
q: 'city:'+val
}).then(function (resp) {
var keywords = [];
for(var i in resp.hits.hits){
var fields = (resp.hits.hits[i]).fields["city"];
keywords.push(fields);
}
return keywords;
}, function (err) {
console.trace(err.message);
});
};
});
这是我的问题
当我使用简单的查询时,上面的代码可以正常工作,但是一旦我通过添加正文来更改查询,它就不起作用了。
angular.module('cineAngularApp')
.controller('AutocompleteCtrl', function ($scope,client) {
$scope.getResult = function(val){
return client.search({
index: 'autocomplete_test',
fields: 'city',
body: {
query: {
match: {
city: val
}
}
}
}).then(function (resp) {
var keywords = [];
for(var i in resp.hits.hits){
var fields = (resp.hits.hits[i]).fields["city"];
keywords.push(fields);
}
return keywords;
}, function (err) {
console.trace(err.message);
});
};
});
我不知道它是否有帮助,但我在调试时也注意到它不再是 POST 请求,而是一个 OPTION 请求。
在此先感谢您的帮助。