【发布时间】:2015-03-14 12:35:48
【问题描述】:
问题是这样的:
如果我使用默认注册控制器,我会被重定向:
- 当用户更新成功时,/users/edit 到 root
- 更新失败时将/users/edit改为/users
因为默认的控制器更新操作如下所示:
if resource_updated
sign_in resource_name, resource, bypass: true
respond_with resource, location: after_update_path_for(resource)
else
clean_up_passwords resource
respond_with resource
end
after_update_path_for 默认设置为root
如果更新失败我会收到设计错误消息和hasError div 包装错误字段
在我的registrations controller edit 操作中,我将值赋予变量@myvar={2, 3}
此变量用于registrations_edit 视图
每当用户更新失败时,我的@myvar 都会收到错误no method .each for nil
我应该如何声明我的视图变量,以便即使更新表单失败也可以访问它们?!
我试过了:
无论如何都强制控制器重定向到edit 视图:
if resource_updated
sign_in resource_name, resource, bypass: true
redirect_to edit_user_registration_path
else
clean_up_passwords resource
redirect_to edit_user_registration_path
end
这造成了问题,因为设计验证不再起作用
编辑-------
我的注册编辑:
def edit
@images = Dir.glob("public/assets/images/users/#{current_user.id}/med/*")
end
我的看法:
<% img_paths = Array.new %>
<% @images.each do |image| %>
<%img_paths.push([
'',
"/assets/images/users/#{current_user.id}/original/#{image.split('/').last}",
{'data-img-src'=>"/assets/images/users/#{current_user.id}/med/#{image.split('/').last}"}
])%>
<% end %>
编辑-----
注册控制器:
class Users::RegistrationsController < Devise::RegistrationsController
def edit
@images = Dir.glob("public/assets/images/users/#{current_user.id}/med/*")
end
def update
if params[:image_file_path]
ff = File.open("public/"+params[:image_file_path])
resource.image = ff
resource.save!
end
self.resource = resource_class.to_adapter.get!(send(:"current_#{resource_name}").to_key)
prev_unconfirmed_email = resource.unconfirmed_email if resource.respond_to?(:unconfirmed_email)
resource_updated = resource.update_with_password(account_update_params)
yield resource if block_given?
if resource_updated
if is_flashing_format?
flash_key = update_needs_confirmation?(resource, prev_unconfirmed_email) ?
:update_needs_confirmation : :updated
set_flash_message :notice, flash_key
end
sign_in resource_name, resource, bypass: true
respond_with resource, location: after_update_path_for(resource)
else
clean_up_passwords resource
respond_with resource
end
end
private
def sign_up_params
params.require(:user).permit(:first_name, :last_name, :email, :password, :password_confirmation, :telephone, :image, :address, :birthday)
end
def account_update_params
params.require(:user).permit(:first_name, :last_name, :email, :password, :password_confirmation, :telephone, :image, :image_file_path, :address, :birthday)
end
protected
def update_resource(resource, params)
resource.update_without_password(params)
end
def after_update_path_for(resource)
edit_user_registration_path
end
end
【问题讨论】:
-
你能分享你的注册控制器吗? ,如果您正在自定义设计注册,那么您必须确保 @images 变量在 1) 成功和 2) 失败的情况下都应该通过查看。
-
你有没有看到如果更新失败那么它不会调用'edit',这就是它给出错误的原因,所以我认为如果你在更新之前设置图像变量会很好
-
我很困惑。
@image变量在#edit操作中设置。如果更新失败,我应该在哪里插入图像以确保它可用?如果更新失败,我曾尝试致电#edit,但随后我丢失了所有设计验证和错误消息。 @Arv -
我不明白什么时候叫什么地方。我只需要让
@images在我的编辑视图中可用,无论调用什么操作。 @Arv -
试试这个可能对你有帮助 before_filter :update ' def set_images @images = Dir.glob("public/assets/images/users/#{current_user.id}/med/*") end '
标签: ruby-on-rails ruby-on-rails-3 ruby-on-rails-4 devise routes