Ruby 2.0.0,Rails 4.0.3需要方法創建並且在實例確實存在時不更新
我有一個_new部分。但是,我用一個實際存在的實例來渲染它。這是必要的,以便我可以通過View和Controller之間的JavaScript傳遞實例ID,因爲我實際上不能傳遞實例本身。我只需在新方法中調用Class.first,以便通過該過程使用現有實例。
我的問題是_new部分提交按鈕識別出該實例已經存在。這導致它更新而不是創建。按鈕字面上說更新。按下時,它將路由到更新方法。這不是我想要的。我想要創建方法,在那裏我將創建一個填充了收集參數的新實例。
怎麼辦?我是否僅僅攜帶一個虛擬實例來啓動流程?如果是這樣,什麼是正確的解決方案?如果這是可接受的,我該如何強制按鈕創建而不是更新?
讚賞所有的幫助和意見。
編輯:我試過按鈕上的變體,試圖強制它觸發到新的方法。它繼續着火更新。我最後的失敗努力是:
<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 %>
控制器租車方法新的地方清除所有領域:
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 2014-09-13 13:55:47
@janfoeh我試圖保持簡單,但這不工作,所以...我已經更新了問題,包括所有相關的部分,形式和方法。問題是我有一系列依賴選擇。當我爲汽車選擇一年的時候,它將返回所有「製造」或那年製造汽車的製造商。等等......爲此,我使用一個實例。請參閱代碼並讓我知道你是否還有其他問題。謝謝。 – 2014-09-13 14:32:56
我認爲你的代碼有一些誤解和徹底的錯誤。我會創建一個空白的,乾淨的版本,試圖實現你的目標,並嘗試清除這些內容。 – janfoeh 2014-09-13 15:44:32