我用ajax请求调用Rails控制器函数。它有效但我收到了一个错误:
ActionView::MissingTemplate
控制器功能是:
# Aktiviert einen Kurs. Diese Action wird von einem AJAX-Aufruf aus aufgerufen
def activate
@course = Course.find params[:id]
return false unless check_authorization @course
@course.active = params[:active]
@course.save
redirect_to :back
end
ajax调用如下所示:
$.ajax({
url: '<%= url_for(:controller => "courses", :action => "activate_lesson") %>',
data: {"id": <%= lesson.id%>, "active": 0}
})
.done(function () {
saved();
})
.fail(function () {
notsaved();
})
如何解决错误?
答案 0 :(得分:2)
当你在控制器中使用动作时,如果你没有说它应该呈现什么特定的模板,它会搜索
app/views/controller_name_without_word_controller/action_name.html.*
在您的情况下,它正在搜索app/views/controller_name/activate.html.*
来呈现它,但您没有该文件。
解决方案是返回json
响应,因为您使用的是ajax
,但您可以返回html
你可以写:
def activate
@course = Course.find params[:id]
return false unless check_authorization @course
@course.active = params[:active]
@course.save
render json: @course # or whatever you want to return
end
答案 1 :(得分:1)
您需要从控制器中渲染json
。
before_filter :authorized?, :only => :activate
def activate
@course.active = params[:active]
if @course.save
render :json => {:status => :ok}
else
render :json => {:errors => @course.errors}
end
end
def authorized?
@course = Course.find params[:id]
render :json => {:status => 401, :error => :unauthorized} unless check_authorization(@course)
end