一尘不染

从Rails中的控制器渲染部分

ajax

我有一种通过remote => true将行添加到数据库的表单。然后,我想将新数据追加到表中,但是无法获取正确的视图来呈现。

到目前为止,它正在为新条目渲染整个show.html.erb页面,但是我想布局一个最小版本以作为添加。有没有一种快速的方法来告诉我的控制器,将其插入数据库后呈现什么视图?我想渲染我的部分名为_newly_added.html.erb

我的控制器

  def new
    @task = Task.new
    render :partial => "/tasks/newly_added", :locals => { :t => @task }
  end

谢谢!!

编辑 我认为我需要的只是一个替代的“显示”视图。

我发现我需要更改的方法实际上是这样的:

  def create
    @task = Task.new(params[:task])

    respond_to do |format|
      if @task.save
        format.html { redirect_to @task, notice: 'Task was successfully created.' }
        format.json { render json: @task, status: :created, location: @task }
      else
        format.html { render action: "new" }
        format.json { render json: @task.errors, status: :unprocessable_entity }
      end
    end
  end

我只需要制作一个替代的显示视图,然后告诉它redirect_to该视图。


阅读 157

收藏
2020-07-26

共1个答案

一尘不染

根据您的问题中的更改进行编辑。但是,什么都没有改变。您正在思考错误的事情,需要调整自己的想法。您不需要其他节目,需要处理format.js请求。

部分内容应在JavaScript响应中呈现,而不是在控制器中呈现。控制器看起来更像这样:

  def create
    @task = Task.new(params[:task])

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

然后,在views / tasks / create.js.coffee中

($ '#mytable').append("<%= j render(partial: 'tasks/newly_added', locals: { t: @task }) %>")

这里发生的是浏览器调用create.jscreate.js由于respond_to块的原因,控制器以模板响应format.js。该j脱的内容_newly_added.html.erb文件,并且它的内容附加到表。控制器不与现有视图交互,而是将JavaScript发送到浏览器,并与视图交互。

如果您正在使用像Backbone或Ember这样的客户端MVC框架,那么所有这些都会有所改变,但是您没有指定它,因此我假设您要使用股票Rails。

2020-07-26