如何避免这个双重渲染问题,我一直试图复制,但做不到。那么下面的代码有什么问题吗?
def check_count
assign_values_from_params
if count >= failed_count
render partial: params[:view_name], layout: false and return
else
render text: 'works' and return
end
end
def assign_values_from_params
# code
# code
# code
if @date.blank?
redirect_to main_index_path and return
end
if @counted_obj != 5
# call one function
end
end另外,我应该这样做吗,Double render error rails?
发布于 2017-11-15 09:59:49
打电话给performed?,看看render或redirect是否已经发生了。
您可能希望将您的to代码更改为如下所示:
def check_count
assign_values_from_params
return if performed?
if count >= failed_count
render(partial: params[:view_name], layout: false)
else
render(text: 'works')
end
end
def assign_values_from_params
# code
if @date.blank?
redirect_to(main_index_path) and return
end
# code
end发布于 2017-11-06 12:06:34
将返回语句从render partial: params[:view_name], layout: false and return中删除,因为在呈现后,它将导致返回零。从这两行中移除返回语句,它应该是固定的。
它应该看起来像这个render text: 'works'。
发布于 2017-11-13 05:41:44
根据我的第一条,检查是否有任何渲染被调用。在遍历代码时,它没有显示,但可能在内部被调用。这样你就可以打电话给演出了?在控制器中检查是否已经调用了呈现:
performed? # => false
render partial: params[:view_name], layout: false
performed? # => true 如果打了电话?第一次说是真的,那么你必须检查你的代码。
https://stackoverflow.com/questions/47136610
复制相似问题