ruby on rails-配置文件选项重定向到帐户设置而不保存



我是Rails的新手。我正在设置用户档案,并在其中添加字段,用户当然可以修改他们的档案信息,如职业、关于我、身高、宗教信仰等。这些信息与注册选项(帐户设置(完全不同。

我遇到的问题是,配置文件页面将转发回帐户设置,并说你必须输入密码,它显示所有帐户设置字段,而不是配置文件字段。因此,我需要的是在用户提交信息后,配置文件页面保持在该页面上,并且我需要将该信息保存到他们的帐户中,以便他们以后可以修改它。

这是用于用户配置文件的show.html文件:

<h1><%= @user.username %></h1>
<h2>Basics</h2>
<%= form_for @user do |f| %>
    <div class="field">
        <%= f.label :height %><br/>
        <%= f.select :about_me, [['Feet', nil], '4', '5', '6'] %>
        <%= f.select :about_me, [['Inches', nil], '0', '1', '2', '3', '4',                  
                                '5', '6', '7', '8', '9', '10', '11'] %>
        </div>
    <div class="field">
        <%= f.label :career %><br/>
        <%= f.text_field :career %>
    </div>
    <div class="actions"><%= f.submit %></div>
<% end %> 

这是用户控制器,我知道我把它重定向到@user,它会把它发送回帐户设置页面,但我不知道该把它设置为什么值,所以它没有:

class UsersController < ApplicationController
  def new
    @user = User.new
  end
  def create
    @user = User.new(params[:user])
    if @user.save
      UserMailer.registration_confirmation(@user).deliver
      session[:user_id] = @user.id
      redirect_to root_url, notice: "Thank you for signing up!"
    else
      render "new"
    end
  end
  def show
    @user = User.find(params[:id])
    if @user.show_profile(params[:user])
      redirect_to @user
    else
      render 'edit'
    end
  end
    def edit
      @user = User.find(params[:id])
end
  def index
    @users = User.all
  end
  def destroy
     User.find(params[:id]).destroy
     flash[:success] = "User deleted."
     redirect_to users_url
   end
def update
    @user = User.find(params[:id])
    if @user.update_attributes(params[:user])
      flash[:success] = "Account updated"
      redirect_to @user
    else
      render 'edit'
    end
end
end

Show方法正在做它应该做的事情。它正在为你展示景色。正如您所定义的,它应该重定向到要显示配置文件的用户,这里就是这样做的。

无论情况如何,您的任务都是调用create方法:

所以你需要做的是:

方法一是在new.html.erb中定义您在show.html.erb中定义的代码。

这样做,就不需要在form_for中显式定义您的路径,因为表单将在内部调用create方法。

方法二是将form_for中的路径明确定义为:

<%= form_for(@user, :url => {:action => :create}) do |f| %>

请注意,方法一是推荐的做你需要的事情的方法,因为这是创建操作的工作,先做方法后的工作,然后做数据库相关的任务。

最新更新