2

我正在尝试 Ajaxify Ruby on Rails 应用程序,以避免在用户交互后重新加载每个页面。

我现在设法在幕后创建了一个新想法,但一旦创建就不会显示它。

这是我的代码:

意见中的形式:

<div id="new_proposition_form" style="display:none">
    <%= form_for(@new_proposition, :remote => true) do |f| %>
        <%= f.text_field :title, :class => "proposition_input", :id => "new_proposition_input"  %>
        <%= f.hidden_field :created_by %>
        <%= f.hidden_field :father_id %>
        <%= f.hidden_field :procontra %>
        <%= f.hidden_field :created_at %>
    <% end %>
</div>

在想法控制器中创建操作:

  def create
    @idea = Idea.new(params[:idea])
    @idea.created_at = Time.now

    respond_to do |format|
      if @idea.save
        format.html { redirect_to play_path, :notice => 'Idea was successfully created.' }
        format.json { render :json => @idea, :status => :created, :location => @idea }
        format.js 
      else
        format.html { render :action => "new" }
        format.json { render :json => @idea.errors, :status => :unprocessable_entity }
      end
    end
  end

在想法视图中创建.js.erb:

$("<%= escape_javascript render(:file => 'ideas/new_proposition.html.erb') %>").insertBefore('#end_of_propositions_list');

其中“end_of_propositions_list”是显示的想法列表的唯一标识符。

我正在努力解决的问题如下:

如果想法视图中的new_proposition.html.erb视图类似于:

<div>
  New proposition added
</div>

使用不引用任何对象或变量的代码,它可以工作,即用户可以看到发生的事情的确认。因此,我知道在浏览器中发起的远程操作命中了控制器,该控制器命中了命中局部视图的 javascript 模板。

现在我希望新创建的想法出现,使用检索其属性并处理格式的部分。我觉得我需要将新创建的想法的 id 从想法控制器中的创建操作传递给由 format.js 调用的 create.js 脚本,然后再传递给部分,以便它知道从数据库中提取什么想法.

我不知道如何处理从创建控制器操作传递到 create.js 和局部视图的参数,非常感谢您的帮助。

4

2 回答 2

2

在我看来很好……?因此,您接下来要做的是将实例变量 @idea 从控制器传递给部分:

$("<%= escape_javascript render(
    :file => 'ideas/new_proposition.html.erb', 
    :idea => @idea) %>")
.insertBefore('#end_of_propositions_list');

然后在您的视图中访问@idea:

<div>New proposition added</div>
<div>Title: <%= @idea.title => </div>

希望有帮助

于 2012-11-20T10:42:43.603 回答
0

在该控制器呈现的视图中,您可以使用 @ 访问变量,因此在 create.js 中您可以直接访问 @idea.id

于 2012-11-20T09:29:02.053 回答