还不如写自己的逻辑,这一点,因为我不认为做一个插件是要提出自己:
我假设城市和国家有ID。如果没有,逻辑实际上会更简单。 使用jQueryUI的自动完成为您的元素触发自动完成。添加一个控制器方法,该方法会将您的城市和国家/地区标签(可能是城市对象上的方法)与您的ID一起作为json。在自动填充“选择”回调中,为城市和国家ID在表单中设置隐藏字段。这最后一部分是可选的,因为我不知道你打算如何从表单中保存这些数据。
下面的例子假设你的应用很多,但应该足以让你开始:
的视图脚本的
例如:
$("#yourField").autocomplete({
source: "/path_to_your_action",
minLength: 2,
select: function(event, ui) {
$(this).val(ui.item.label);
$(this).find("#country_id").val(ui.item.country_id);
$(this).find("#city_id").val(ui.item.city_id);
event.preventDefault;
}
})
控制器:
def your_action
term = params[:term]
cities = City.where("cities.name like ?", "%#{term}%")
.limit(25)
.all
render :json=>cities.collect{|c| {:label=>c.your_label_method, :city_id=>c.id, :country_id=>c.country_id}}
end
city.rb
def your_label_method
"#{self.name}, #{self.country.name)}"
end
有一个很好的方式在这个正确的方向,thx! – Rubytastic 2012-02-03 15:42:20