【问题标题】:How to pass in javascript variables into a Rails controller?如何将 javascript 变量传递给 Rails 控制器?
【发布时间】:2014-06-09 05:30:16
【问题描述】:

我正在为我的一个小项目使用 gmap4rails。我想从用户当前位置传入纬度和经度值,并将这些值设置到我的模型中,称为 Pet。宠物模型属于用户模型,用户模型有很多宠物。我希望能够在创建新宠物时执行此操作,以便宠物收养信息具有坐标。

我了解对于 AJAX 请求,它需要一个 url 来了解它应该采用哪条路径。由于宠物属于模型,因此我不确定如何将路径添加到 url 参数中。我做了一个 rake routes 来查看要使用哪个路由,理想情况下我应该使用 POST 路由:

/users/:user_id/pets(.:format)

我是按原样将其复制到 url 中,还是需要以某种方式使用 js 获取 user_id?

到目前为止,我已经创建了一个如下所示的 js 文件:

var lat;
var lon;

$(document).ready(function() {
if(navigator.geolocation) {
    navigator.geolocation.getCurrentPosition(setLatLon);
}

function setLatLon(position) {
    lat = position.coords.latitude;
    lon = position.coords.longitude;
}
//function for logging in and passing lat and lon to the controller
$(function() {
    $("#save").click(function() {
        //create ajax request
        console.log("creating ajax request")
        $.ajax({
            type: 'POST',
            url: "users/pets",
            data: 'lat=' + lat + '&lon=' + lon
        })
    });
});
});

宠物模型:

class Pet < ActiveRecord::Base
    belongs_to :user
    validates :name, presence: true
    validates :species, presence: true
    validates :breed, presence: true
    validates :description, presence: true

    def self.setCoords(lat, lon)
        self.lat = lat
        self.lon = lon
    end
end

宠物控制器创建定义:

def create
    @user = User.find(params[:user_id])
    @pet = @user.pets.create(pet_params)
    @pet.setCoords(params[:lat], params[:lon])
    if @pet.save
        redirect_to user_path(@user)
    else 
        render 'new'
    end
end

控制台出错:

creating ajax request getCoords.js?body=1:17
POST http://localhost:3000/users/1/pets/users/pets 404 (Not Found) jquery.js?body=1:9667
POST http://localhost:3000/users/1/pets 500 (Internal Server Error) jquery.js?body=1:9667

尝试将 js 文件保存为 js.erb 文件会更好吗?我想也许我可以嵌入我从 rake 路线中得到的路线......

【问题讨论】:

  • 您当前所在的网址是什么?
  • 实现有一些问题。单击时有 2 个 POST 请求 POST http://localhost:3000/users/1/pets/users/pets 404 (Not Found)POST http://localhost:3000/users/1/pets 500
  • 第二个请求确实到达了服务器,但是代码有错误

标签: javascript ruby-on-rails ajax gmaps4rails


【解决方案1】:

我是按原样将其复制到 url 中,还是需要以某种方式使用 js 获取 user_id?

如果您阅读了帖子末尾包含的控制台中的错误,您会看到您正在发送两个 AJAX 请求。就像 Santosh 在 cmets 中所说的那样,您应该找出原因并解决此问题。但是为了解释错误,第一个错误被发送到 users/1/pets/users/pets 因为您的 ajax 调用的 url 选项设置为“users/pets”,这会将其附加到默认路由,而该路由不会存在(因此是 404)。第二个 AJAX 请求被发送到正确的 URL,但返回 500 错误。如果您查看服务器控制台,您将看到一条消息。 (提示:每当浏览器控制台报告500 (Internal Server Error) 时,请查看您的服务器终端或日志以了解详细信息。)

您的其他代码也有一些问题。首先,您已将 setCoords 定义为模型中的类方法(使用self.setCoords),但在您的控制器中,您在该类的实例(@pet)上调用它。当程序到达该行时,这将导致 NoMethodError。要解决此问题,请从方法定义中删除 self,使其仅读取为 setcoords(lat, lon)

其次,您将 AJAX 调用路由到实际接受 AJAX 请求的控制器操作是吗?你需要有一个这样的块:

respond_to do |format|
  format.html
  format.js {
    # do stuff
  }
end

如果处理请求的是 create 操作,那么您将需要上述块,还需要一个 create.js.erb 文件(默认情况下),该文件将包含要发送回浏览器的 JavaScript 代码刷新页面状态。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2015-11-02
    • 1970-01-01
    相关资源
    最近更新 更多