0

我正在尝试构建一个动态菜单,因此当用户选择一个国家/地区时,状态菜单会更新。

我正在查看我的开发日志,我看到该操作运行 db 查询,然后呈现 json.erb 文件,但我无法从浏览器获得任何响应。

这是我所拥有的:

控制器/settings_controller.rb

respond_to :html, :json

  def getstates
    @states = Country.find_by_iso(params[:account][:addresses_attributes]["0"][:country]).states
    respond_with(@states)
  end

(注意:表单是嵌套表单,这就是为什么 params 哈希这么长。)


设置/edit.html.erb

<%= address.collection_select :country, Country.order(:name), :iso, :name, {:include_blank => true}, "data-remote" => true, "data-url" => "/settings/getstates", "data-type" => :json  %>

<%= address.select :state, [], {:include_blank => true}, :disable => true %>

设置/getstates.json.erb

$(document).ready(function() {

    $("#account_addresses_attributes_0_country").bind('ajax:success', function(evt, data, status, xhr){
      var select = $('#account_addresses_attributes_0_state');

      if (data !== null) {
        select.removeAttr('disabled');
        $.each(data, function(key, value) {
          $("<option/>").val(value[1]).text(value[0]).appendTo(select);
        });
      } else {
        select.empty();
        select.attr('disabled', 'disabled');
      }
    });
});

(注意:我从http://blog.madebydna.com/all/code/2011/12/05/ajax-in-rails-3.html获得此代码)


开发日志

Processing by SettingsController#getstates as JSON
  Parameters: {"account"=>{"addresses_attributes"=>{"0"=>{"country"=>"UY"}}}}
  User Load (0.1ms)  SELECT "users".* FROM "users" WHERE "users"."id" = ? LIMIT 1  [["id", "1"]]
  Country Load (0.2ms)  SELECT "countries".* FROM "countries" WHERE "countries"."iso" = 'UY' LIMIT 1
  Rendered settings/getstates.json.erb (0.3ms)
Completed 200 OK in 3ms (Views: 1.5ms | ActiveRecord: 0.3ms)

这是我在开发日志中看到的输出。但在浏览器中什么都没有。我尝试添加警报和控制台日志方法,但没有。

如果有人能帮助我理解我做错了什么,我将不胜感激。

4

2 回答 2

1

首先,我对您的 .json.erb 视图有点困惑。当 REST 请求请求 JSON 时,您似乎正在返回 Javascript(在浏览器中执行)。

其次,我会看看你最喜欢的类似Firebug的工具(无论是 Chrome 的开发者工具还是 Safari 的......随便。看看你向服务器发出的 AJAX 请求返回了什么。(也许不是你所期望的 - 一个错误代码或者你得到的东西与你 - 或collection_select期望的不同)。

我的猜测是您的 .json 视图正在吐回实际的 Javascript,然后(某些东西)尝试解析为 JSON,失败并在某处给出 Javascript 错误消息(中止 Javascript)。同样,追踪其中之一的最简单方法是使用类似 Firebug 的方法。

于 2012-04-16T21:38:37.700 回答
1

如果您使用 Firebug 的控制台选项卡,您将看到发出 ajax 请求。然后您可以打开它并查看响应正文。就像 Ryan 建议您请求 JSON 但返回完整的 javascript 一样。因此,如果您要保持这种方式,则必须在回调函数中评估响应,即 eval(data) 或 jQuery 也有一个快捷方式,您可以在其中请求“脚本”类型;但是现在 RJS 已经从 Rails 中删除了,这有点令人不悦。相反,按照 Dan 的建议,将 settings/getstates.json.erb 的内容移动到您的编辑视图中,然后删除 getstates.json.erb 文件。为了帮助您完成这项工作,现在让请求/响应更简单。只需执行此操作并在 Firebug 中检查它以查看发生了什么。之后,将其连接起来以将响应内容转换为您的选项标签

$.get("/settings/getstates", function(data){
  console.log(data);
}, 'json')
于 2012-04-17T07:00:57.120 回答