我使用的是API而不是数据库,所以我不使用ActiveRecord,而是使用ActiveModel (我主要喜欢这里:Railscasts.com/API/219-active-model)
问题是,当我试图编辑一个项目(在我的例子中是一个停车场)时,表单的操作仍然是创建的动作,而不是更新。
因此,当我继续/ parking /2/编辑来编辑一个停车场时,表单仍然是:
<form accept-charset="UTF-8" action="/parkings" class="form-horizontal" id="new_parking" method="post">当它应该更像以put隐藏字段和parking/2作为动作时:
<form accept-charset="UTF-8" action="/parkings/2" class="form-horizontal" id="edit_parking" method="post"><div style="margin:0;padding:0;display:inline"><input name="utf8" type="hidden" value="✓" /><input name="_method" type="hidden" value="put" />有人知道form_for的方法和动作是根据路线设置的吗?我想要做的是,就像我在数据库中使用ActiveRecord一样。
以下是一些代码:
_form.html.erb
<%= form_for(@parking, :html => { :class => "form-horizontal" }) do |f| %>
...
<% end %>edit.html.erb & new.html.erb,简单地说有
<%= render 'form' %>控制器
class ParkingsController < ApplicationController
def index
@parkings = Parse.get("Parking")
respond_to do |format|
format.html
format.json { render :json => @parking }
end
end
def new
@parking = Parking.new
respond_to do |format|
format.html
format.json { render :json => @parking }
end
end
def edit
@parking = Parking.find(params[:id])
respond_to do |format|
format.html
format.json { render :json => @parking }
end
end
def create
@parking = Parking.new(params[:parking])
if (@parking.save)
flash[:success] = "Parking was just added!"
redirect_to :action => "new"
else
render :action => "new"
end
end
def update
# Testing
parking = Parse.get("Parking", params[:id])
parking.delete("updatedAt")
parking["name"] = params[:parking][:name]
parking.save
redirect_to :action => "index"
end模型
class Parking
include ActiveModel::Validations
include ActiveModel::Conversion
extend ActiveModel::Naming
attr_accessor :name, :address, :city, :longitude, :latitude, :contributor_name, :contributor_email
validates_presence_of :name, :address, :city, :longitude, :latitude
@id = nil
def initialize(attributes = {})
attributes.each do |name, value|
send("#{name}=", value)
end
end
def self.find(id)
@id = id
raw = Parse.get("Parking", @id.to_s)
parking = Parking.new
parking.name = raw["name"]
parking.address = raw["address"]
parking.city = raw["city"]
parking.longitude = raw["location"]["longitude"]
parking.latitude = raw["location"]["latitude"]
parking.contributor_name = raw["contributorName"]
parking.contributor_email = raw["contributorEmail"]
return parking
end
def save
if (!valid?)
return false
else
parking = Parse::Object.new("Parking")
data =
{
:longitude => longitude.to_f,
:latitude => latitude.to_f
}
point = Parse::GeoPoint.new(data)
parking["location"] = point
parking["name"] = name
parking["address"] = address
parking["city"] = city
parking["contributorName"] = contributor_name
parking["contributorEmail"] = contributor_email
if (parking.save)
return true
end
end
end
def persisted?
false
end
end请注意,创建正在工作,如果我在表单action=中添加了我的停车位id“使用网络检查器或Firebug,并在我的form_for中添加:method => "put”,则我的记录将成功更新。
这里真正的问题是form_for操作和方法,当我编辑一个停车位时,这个操作和方法没有得到更新,就像我在添加一个新的停车位一样。
我还在学习Rails,如果有些信息不清楚,我很抱歉!
谢谢!
--溶液
坚持?不应该只返回false,而且我的模型需要定义一个返回对象id的方法(这样他们就可以更新action=""),下面是我更新的模型:
class Parking
include ActiveModel::Validations
include ActiveModel::Conversion
extend ActiveModel::Naming
attr_accessor :objectId, :name, :address, :city, :longitude, :latitude, :contributor_name, :contributor_email
validates_presence_of :name, :address, :city, :longitude, :latitude
@id = nil
def initialize(attributes = {})
attributes.each do |name, value|
send("#{name}=", value)
end
end
def self.find(id)
raw = Parse.get("Parking", id.to_s)
parking = Parking.new
parking.objectId = id
parking.name = raw["name"]
parking.address = raw["address"]
parking.city = raw["city"]
parking.longitude = raw["location"]["longitude"]
parking.latitude = raw["location"]["latitude"]
parking.contributor_name = raw["contributorName"]
parking.contributor_email = raw["contributorEmail"]
return parking
end
def save
if (!valid?)
return false
else
parking = Parse::Object.new("Parking")
data =
{
:longitude => longitude.to_f,
:latitude => latitude.to_f
}
point = Parse::GeoPoint.new(data)
parking["location"] = point
parking["name"] = name
parking["address"] = address
parking["city"] = city
parking["contributorName"] = contributor_name
parking["contributorEmail"] = contributor_email
if (parking.save)
return true
end
end
end
def update_attributes(aParking)
parking = Parse.get("Parking", @id.to_s)
parking.delete("updatedAt")
parking["name"] = aParking["name"]
parking.save
return true
end
def destroy
parking = Parse.get("Parking", @id)
#parking.parse_delete
end
def id
return self.objectId
end
def persisted?
!(self.id.nil?)
end
end发布于 2012-03-06 05:26:20
我认为您的问题在模型的persisted?方法中。因为它总是返回false,Rails总是认为它正在为新创建的记录构建一个表单,所以它使用POST并提交到集合URL。
在该方法中需要某种逻辑,以便现有记录返回true,新记录返回false。
发布于 2012-03-06 06:06:44
嗨,朋友,您可以告诉表单生成器要尝试哪种方法use.So。
<%= form_for(@parking, :method => ["new", "create"].include?(action_name) ? :post : :put,
:html => { :class => "form-horizontal" }) do |f| %>
...
<% end %>发布于 2012-03-06 08:35:41
如果您不使用ActiveRecord,则应该使用“form_tag”而不是“form_for”
https://stackoverflow.com/questions/9577975
复制相似问题