searchkick - 自动完成多个属性
searchkick - Autocomplete with multiple attributes
使用给定的单个属性进行搜索时,自动完成工作正常 here。
可以通过->(根据this)
自动完成多个属性,例如(名称、城市、国家)
def autocomplete
Doctor.search(params[:query], autocomplete: true, limit: 10).map{|doctor| doctor.slice(:name, :city, :country) }
end
然而,这会导致自动完成 dropdown/suggestions 显示 "undefined"。
对于提前输入,我正在使用:
<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/typeahead.js/0.9.3/typeahead.min.js"></script>
在代码中它被引用:
$( function () {
$("#search").typeahead({
name: "doctor",
remote: "/doctors/autocomplete?query=%QUERY"
});
});
由于返回了不止一组数据,是否需要对 typeahead js 文件进行一些更改?
你需要return一个hash
您在 doctors
控制器中的 autocomplete
操作需要如下所示:
def autocomplete
render json: Doctor.search(params[:query], autocomplete: true, limit: 10).map do |doctor| { name: doctor.name, city: doctor.city, country: doctor.country }
end
end
在您的预输入选项中添加 displayKey
:
$( function () {
$("#search").typeahead({
name: "doctor",
displayKey: 'name',
remote: "/doctors/autocomplete?query=%QUERY"
});
});
您还可以阅读 this 文章,看看是否有帮助。
基于以上答案和this and
工作原理如下所示:
def autocomplete
names = Doctor.search(params[:query], fields: [{name: :text_start}], limit: 10).map {|Doctor| {store: doctor.name, value: doctor.id}}
collegenames = Doctor.search(params[:query], fields: [{collegename: :text_start}], limit: 10).map {|Doctor| {store: doctor.collegename, value: doctor.id}}
render json: (names + collegenames)
end
变量存储:现在包含所有数据。
Javascript:
var ready;
ready = function() {
console.log("dfdf")
var numbers = new Bloodhound({
datumTokenizer: function(d) {
console.log(d);
return Bloodhound.tokenizers.whitespace('value');
},
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url:"/doctors/autocomplete?query=%QUERY"
}
});
// initialize the bloodhound suggestion engine
var promise = numbers.initialize();
promise
.done(function() { console.log('success!'); })
.fail(function() { console.log('err!'); });
// instantiate the typeahead UI
$('.typeahead').typeahead(null, {
displayKey: 'store',
source: numbers.ttAdapter()
});
}
$(document).ready(ready);
$(document).on('page:load', ready);
自动完成在这两个领域都很好用,但是现在我在写 url like
时得到一个空数组
http://localhost:3000/doctors/autocomplete?query="a"
使用给定的单个属性进行搜索时,自动完成工作正常 here。
可以通过->(根据this)
自动完成多个属性,例如(名称、城市、国家)def autocomplete
Doctor.search(params[:query], autocomplete: true, limit: 10).map{|doctor| doctor.slice(:name, :city, :country) }
end
然而,这会导致自动完成 dropdown/suggestions 显示 "undefined"。
对于提前输入,我正在使用:
<script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/typeahead.js/0.9.3/typeahead.min.js"></script>
在代码中它被引用:
$( function () {
$("#search").typeahead({
name: "doctor",
remote: "/doctors/autocomplete?query=%QUERY"
});
});
由于返回了不止一组数据,是否需要对 typeahead js 文件进行一些更改?
你需要return一个hash
您在 doctors
控制器中的 autocomplete
操作需要如下所示:
def autocomplete
render json: Doctor.search(params[:query], autocomplete: true, limit: 10).map do |doctor| { name: doctor.name, city: doctor.city, country: doctor.country }
end
end
在您的预输入选项中添加 displayKey
:
$( function () {
$("#search").typeahead({
name: "doctor",
displayKey: 'name',
remote: "/doctors/autocomplete?query=%QUERY"
});
});
您还可以阅读 this 文章,看看是否有帮助。
基于以上答案和this and
工作原理如下所示:
def autocomplete
names = Doctor.search(params[:query], fields: [{name: :text_start}], limit: 10).map {|Doctor| {store: doctor.name, value: doctor.id}}
collegenames = Doctor.search(params[:query], fields: [{collegename: :text_start}], limit: 10).map {|Doctor| {store: doctor.collegename, value: doctor.id}}
render json: (names + collegenames)
end
变量存储:现在包含所有数据。
Javascript:
var ready;
ready = function() {
console.log("dfdf")
var numbers = new Bloodhound({
datumTokenizer: function(d) {
console.log(d);
return Bloodhound.tokenizers.whitespace('value');
},
queryTokenizer: Bloodhound.tokenizers.whitespace,
remote: {
url:"/doctors/autocomplete?query=%QUERY"
}
});
// initialize the bloodhound suggestion engine
var promise = numbers.initialize();
promise
.done(function() { console.log('success!'); })
.fail(function() { console.log('err!'); });
// instantiate the typeahead UI
$('.typeahead').typeahead(null, {
displayKey: 'store',
source: numbers.ttAdapter()
});
}
$(document).ready(ready);
$(document).on('page:load', ready);
自动完成在这两个领域都很好用,但是现在我在写 url like
时得到一个空数组http://localhost:3000/doctors/autocomplete?query="a"