选中时复选框返回false而不是true - Rails 4.2

时间:2016-09-07 14:08:37

标签: ruby validation ruby-on-rails-4 checkbox devise


因此,我正在尝试使用Ruby on Rails为学校项目构建一个电子商务网站,为用户使用Devise。 我仍在自己学习这门语言,我遇到了一个问题。

我已通过设计生成此视图: views / devise / registrations / new.html.erb

<%= bootstrap_form_for(resource, as: resource_name, url: registration_path(resource_name)) do |f| %>
  <%= devise_error_messages! %>

  <div class="field">
    <%= f.text_field :prenom, autofocus: true %>
 </div>

<div class="field">
  <%= f.text_field :nom, autofocus: true %>
</div>

<div class="field">
  <%= f.text_field :adresse, autofocus: true %>
</div>  

<div class="field">
  <%= f.number_field :cp, autofocus: true %>
</div>

<div class="field">
  <%= f.email_field :email, autofocus: true, placeholder: "Ex: votre@mail.com" %>
</div>

<div class="field">
  <% if @validatable %>
    <%= f.password_field :password, autocomplete: "off", placeholder: "8 caractères minimum" %>
  <% end %>
</div>

<div class="field">
  <%= f.password_field :password_confirmation, autocomplete: "off" %>
</div>

<div class="field">
  <%= f.check_box :admin %>
</div>

<div class="actions">
  <%= f.submit "Sign up" %>
</div>
  

我知道我不应该在我的表单中提供管理字段,但这仅用于测试目的。 因此,当我选中复选框并提交此表单时,它将返回false。 我不知道为什么。任何帮助,解释,非常感谢。

我的 user_controller ,如果需要:

class UsersController < ApplicationController
  before_action :set_user, only: [:show, :edit, :update, :destroy]

  # Fais appel à la méthode permettant de restreindre l'accès uniquement aux admins
  # before_filter :authorize_admin, only: :index

  # GET /users
  # GET /users.json
  def index
    @users = User.all
  end

  # GET /users/1
  # GET /users/1.json
  def show
    @user = User.find(params[:id])
  end

  # GET /users/new
  def new
    @user = User.new
  end

 # GET /users/1/edit
 def edit
 end

 # POST /users
 # POST /users.json
 def create
   @user = User.new(user_params)

   respond_to do |format|
     if @user.save
       format.html { redirect_to @user, notice: 'User was successfully created.' }
       format.json { render :show, status: :created, location: @user }
    else
      format.html { render :new }
      format.json { render json: @user.errors, status: :unprocessable_entity }
    end
  end
end

# PATCH/PUT /users/1
# PATCH/PUT /users/1.json
def update
  respond_to do |format|
    if @user.update(user_params)
      format.html { redirect_to @user, notice: 'User was successfully updated.' }
      format.json { render :show, status: :ok, location: @user }
    else
      format.html { render :edit }
      format.json { render json: @user.errors, status: :unprocessable_entity }
    end
  end
end

# DELETE /users/1
# DELETE /users/1.json
def destroy
  @user.destroy
  respond_to do |format|
    format.html { redirect_to users_url, notice: 'User was successfully destroyed.' }
    format.json { head :no_content }
  end
end

private
# Use callbacks to share common setup or constraints between actions.
def set_user
  @user = User.find(params[:id])
end

# Never trust parameters from the scary internet, only allow the white list through.
def user_params
  params.fetch(:user, {})
end
end

2 个答案:

答案 0 :(得分:0)

我在代码中没有看到你使用:admin复选框值的地方,但我猜你也许只是问这个参数是否为true,就像所以?

if params[:user][:admin] == true
  do this...
else
  do this...
end

问题在于,如果选中,则提交的复选框值默认为"1"(请注意,它的类型为string)。任何值的文本字符串都不等于truefalse的布尔值。

您可以将代码更新为:

if params[:user][:admin] == "1"
  do this...
else
  do this...
end

Rails始终会将提交的参数作为string

接收

答案 1 :(得分:0)

关键位在最后:

# Never trust parameters from the scary internet, only allow the white list through.
def user_params
  params.fetch(:user, {})
end

白名单(第二个参数)为空,因此忽略所有参数。如果查看日志文件,您会看到有关忽略参数的警告(您可以将其配置为引发异常)。

如果正在使用的控制器是您的UsersController或设计注册控制器,则不清楚 - 您已经显示了一个视图,而另一个显示了控制器代码。

如果您使用的是设计注册控制器,那么UsersController可能不相关 - 您通常会使用之前的过滤器来运行这样的事情

devise_parameter_sanitizer.permit(:sign_up, keys: [:admin, ...])

更改设计的默认允许字段列表。