微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

ruby-on-rails – 适用于城市,国家/地区的Rails / Jquery Autocomplete自动完成插件

我正在寻找一个可以处理的好的 Jquery插件
查找城市所属的国家/地区(具有自动填充的类型)

例如:

Typing "New Yor"

自动完成

New York,United States

并能够拯救城市和国家

:city
:country

什么是实现这种功能的好方法?我的意思是将所有国家和城市存储在用户数据库中.我知道https://github.com/jim/carmen但是那个正在被重写,我很乐意自己解决这个问题,只需要一些帮助.

解决方法

不妨为此编写自己的逻辑,因为我认为插件不会出现:

我假设这个城市和国家有ids.如果没有,逻辑实际上会更简单.
使用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

原文地址:https://www.jb51.cc/ruby/264506.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐