5

我的表格:

<%= semantic_form_for(@campaign) do |f| %>
...
  <%= f.actions do %>
    <%= f.action :submit, label: "Save"%>
    <%= f.action :submit, label: "Save & New" %>
    <%= f.action :cancel, label: "Cancel"%>
  <% end %>
<% end %>

Campaign_controller.rb 中的函数:

  def save_and_new
    print 'SAVE_AND_NEW'
    @campaign = Campaign.find(params[:id])

    respond_to do |format|
      if @campaign.update_attributes(params[:campaign])
        format.html { redirect_to new_campaign_path, notice: 'Campaign was successfully usaved.' }
        format.json { head :no_content }
      else
        format.html { render action: "edit" }
        format.json { render json: @campaign.errors, status: :unprocessable_entity }
      end
    end
  end

路线.rb:

  resources :campaigns do 
    member do
      post 'save_and_new'
    end
  end

路线,按功能:

save_and_new_campaign POST   /campaigns/:id/save_and_new(.:format) campaigns#save_and_new

唯一我不明白的是,在调用函数时要写什么。

4

1 回答 1

2

我不确定你到底想用这个save_and_new动作做什么,但我可以告诉你为什么你没有触发它。

默认情况下,您使用 formtastic 创建的表单semantic_form_for将使用 RESTful 约定,即点击create新记录的update操作和现有记录的操作。如果您使用第一个提交按钮(标记为“保存”)成功点击create/update操作,但您希望第二个“保存和新建”按钮执行不同的操作,则需要检查params[:commit]控制器中 fork的值您对提交的处理。也许一些代码会更清楚。假设您正在提交更新现有记录:

def create
  if params[:commit] == "Save"
    # code for handling "Save" scenario
  else
    # code for handling "Save & New" scenario, perhaps even directly call:
    save_and_new
  end
end


def update
  if params[:commit] == "Save"
    # code for handling "Save" scenario
  else
    # code for handling "Save & New" scenario, perhaps even directly call:
    save_and_new
  end
end

同样,我不清楚您要通过该save_and_new操作完成什么,并且质疑该假设可能会使您走上更好设计的道路,但要回答您的直接问题:检查params[:commit]in的值createupdate应该让您正确的轨道。

于 2012-04-26T19:32:15.477 回答