【发布时间】:2014-09-17 00:02:43
【问题描述】:
Ruby 2.0.0、Rails 4.0.3
我有一个 _new 部分。但是,我用一个实际存在的实例来渲染它。这是必要的,以便我可以通过 JavaScript 在视图和控制器之间传递实例 ID,因为我实际上无法传递实例本身。我只是在新方法中调用 Class.first,这样我就有一个现有的实例可以在整个过程中使用。
我的问题是 _new 部分提交按钮识别出该实例已经存在。这会导致它更新而不是创建。该按钮字面意思是更新。按下时,它会路由到更新方法。那不是我想要的。我想要 create 方法,我将在其中创建一个填充了收集的参数的新实例。
怎么办?我只是携带一个虚拟实例来启动该过程是错误的吗?如果是这样,正确的解决方案是什么?如果这是可以接受的,我如何强制按钮创建而不是更新?
感谢所有帮助和 cmets。
编辑:我尝试了按钮的变体,试图强制它触发新方法。它继续触发更新。我最后一次失败的努力是:
<button type="submit" formaction="new_admin_car_path" class="btn btn-default btn btn-primary">Create Car</button>
...结束编辑...
形式为:
<div class="span8">
<% car_id = @car.id %>
<%= simple_form_for [:admin, @car],
defaults: {label: false},
html: {id: 'new_admin_car', class: 'form-vertical', method: post},
wrapper: :vertical_form,
wrapper_mappings: {
check_boxes: :vertical_radio_and_checkboxes,
radio_buttons: :vertical_radio_and_checkboxes,
file: :vertical_file_input,
boolean: :vertical_boolean
} do |f| %>
<%= f.input(:stock_number, {input_html: {form: 'new_admin_car', car: @car, value: nil}, autocomplete: :off, placeholder: 'Stock number?'}) %>
<%= f.input(:ymm_year_id, {input_html: {form: 'new_admin_car', car_id: car_id, value: nil}, collection: YmmYear.all.order("year desc").collect{|c| [c.year, c.id]}, prompt: "Year?"}) %>
<%= render partial: "makes", locals: {form: 'new_admin_car', car_id: car_id} %>
<%= render partial: "models", locals: {form: 'new_admin_car', car_id: car_id} %>
<%= f.association(:color, {input_html: {form: 'new_admin_car', value: nil}, autocomplete: :off, prompt: 'Color?'}) %>
<div class="col-xs-6 col-sm-3">
<br/>
<input type="submit" form="new_admin_car" value="Create Car" class="btn btn-default btn btn-primary">
<% end %>
</div>
</div>
局部化:
<% unless car_id.blank? %>
<% car = Car.find(car_id) %>
<%# car.ymm_make_id = nil %>
<%= simple_form_for [:admin, car],
defaults: {label: false},
remote: true do |f| %>
<% makes ||= "" %>
<% make = "" %>
<% make = car.make_id if car.class == Car and Car.exists?(car.id) %>
<% if !makes.blank? %>
<%= f.input :ymm_make_id, {input_html: {form: form, car: car, car_id: car.id, value: make}, collection: makes.collect { |s| [s.make, s.id] }, prompt: "Make?"} %>
<% else %>
<%= f.input :ymm_make_id, {input_html: {form: form, car: car, car_id: car.id, value: make}, collection: [], prompt: "Make?"} %>
<% end %>
<% end %>
<% end %>
Controller Car Method New where clear 只是清除所有字段:
def new
@car = Car.first
@car.clear
end
呈现形式:
表单的 JavaScript 是:
// when the #year field changes
$("#car_ymm_year_id").change(function () {
// make a GET call and replace the content
// First select identifies what has been selected, or fired
var year = $('select#car_ymm_year_id :selected').val();
// Pull the variables from the input_html tag
var form = $('select#car_ymm_year_id').attr("form");
var car_id = $('select#car_ymm_year_id').attr("car_id");
// Routes to the controller action
$.post('/admin/cars/make_list/',
{
form: form,
year: year,
car_id: car_id
},
function (data) {
$("#car_ymm_make_id").html(data);
});
return false;
});
控制器方法:
def make_list
makes = YmmMake.makes(params[:year])
#@car = Car.find(params[:car_id])
render partial: "makes", locals: {car_id: params[:car_id], form: params[:form], makes: makes}
end
【问题讨论】:
-
您能否详细说明通过 JavaScript 在视图和控制器之间传递实例 ID 的含义?我们也许可以在那里找到更好的解决方案,并从一开始就避免整个事情。使用现有实例,然后强制表单助手将其视为带有撬棒的新实例确实听起来是个坏主意。
-
@janfoeh 我试图保持简单,但这并不奏效……我已经更新了问题以包括所有相关的部分、表单和方法。问题是我有一系列依赖选择。当我为汽车选择一年时,它会返回当年制造汽车的所有“制造商”或制造商。等等......为此,我使用了一个实例。请参考代码,如果您还有其他问题,请告诉我。谢谢。
-
我认为您的代码存在一些误解和完全错误。我将创建一个空白的、干净的版本,说明您正在尝试实现的目标,并尝试在此过程中清除它们。
标签: javascript ruby-on-rails ruby