
根据您的问题中的更改进行编辑。但是,什么都没有改变。您正在思考错误的事情,需要调整自己的想法。您不需要其他节目,需要处理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.js。
create.js由于
respond_to块的原因,控制器以模板响应
format.js。该
j脱的内容
_newly_added.html.erb文件,并且它的内容附加到表。控制器不与现有视图交互,而是将Javascript发送到浏览器,并与视图交互。
如果您正在使用像Backbone或Ember这样的客户端MVC框架,那么所有这些都会有所改变,但是您没有指定它,因此我假设您要使用股票Rails。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)