【问题标题】:How to solve undefined method `permit' for :user:Symbol error in ror-4如何解决 ror-4 中:user:Symbol 错误的未定义方法“permit”
【发布时间】:2015-01-12 11:08:00
【问题描述】:

请帮我解决这个错误。执行更新操作时,会显示此错误。

错误:

NoMethodError in UsersController#update
undefined method `permit' for :user:Symbol

我的代码 sn-ps 如下。

views/users/edit.html.erb

<h1>Edit your data</h1>
<%= form_for @user,:url => {:action => 'update',:id => params[:id]} do |f| %>
    <% if @user.errors.any? %>
        <div id="error_explanation">
          <h2><%= pluralize(@user.errors.count, "error") %> prohibited this post from being saved:</h2>

          <ul>
            <% @user.errors.full_messages.each do |message| %>
                <li><%= message %></li>
            <% end %>
          </ul>
        </div>
    <% end %>
    <%= f.text_field:name,:value => @edit.name %>
    <%= f.email_field:email,:value => @edit.email %>
    <%= f.text_field:message,:value => @edit.message %>
    <%= f.submit "Update" %>
<% end %>
<%= link_to "Back",users_index_path %>

controller/users_controller.rb

class UsersController < ApplicationController
  def index

  end
  def new
    @user=User.new
  end
  def create
    @user=User.new(users_params)
    if @user.save
      flash[:notice]="Your data is saved succesfully"
      flash[:color]="valid"
      redirect_to :action => 'index'
    else
      flash[:alert]="You are entering wrong data"
      flash[:color]="invalid"
      render :new
    end
  end
  def show
    @user=User.all
  end
  def delete
   @user=User.find(params[:id])
    if @user.delete
      flash[:notice]=@user.name+"has deleted successfully"
      flash[:color]="valid"
      redirect_to :action => 'index'
    else
      flash[:alert]=@user.name+"could not delete.Please check it.."
      flash[:color]="invalid"
      render :show
    end
  end
  def edit
    @edit=User.find(params[:id])
    @user=User.new
  end
  def update
    @user=User.find(params[:id])
    if @user.update_attributes(update_params)
      flash[:notice]="Your data has updated successfully"
      flash[:color]="valid"
      redirect_to :action => 'index'
    else
      flash[:alert]="Your data could not update..check it.."
      flash[:color]="invalid"
      render :edit

    end
  end
  private
  def users_params
    params.require(:user).permit(:name, :email, :message,pets_attributes: [:name, :email,:message])
  end
  def update_params
    params.require (:user).permit(:name,:email,:message,pets_attributes: [:name, :email,:message])
  end
end

model/user.rb

class User < ActiveRecord::Base
  has_many :pets
  accepts_nested_attributes_for :pets
  EMAIL_REGEX = /\A[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}\z/i
  validates :name,  :presence => true,:length => { :minimum => 5 }
  validates :email, :presence => true, :uniqueness => true, :format => EMAIL_REGEX
  validates :message,  :presence => true
end

请帮我解决上述错误。

【问题讨论】:

  • 过去几周你问了很多问题,但你连一个答案都没有接受。要成为 StackOverflow 社区的一员,您需要为好的答案投票,并接受对您的问题最有帮助的答案(如果有的话)。请通读帮助中心了解更多信息。

标签: ruby ruby-on-rails-3 ruby-on-rails-4


【解决方案1】:

require(:user) 之间有空格。您当前的代码相当于:

def update_params
  params.require(:user.permit(:name,:email,:message,pets_attributes: [:name, :email,:message]))
end

正如您现在所看到的,您在 :user 符号上调用 permit 方法,这是错误的直接原因。

应该是:

  def update_params
    params.require(:user).permit(:name,:email,:message,pets_attributes: [:name, :email,:message])
  end

顺便说一句,有两种方法做完全相同的事情是毫无意义的。

【讨论】:

  • @subhra 我的回答有帮助吗?
【解决方案2】:

检查您的问题:

you have a space after require and before (:user) 

试试:

 def update_params
   params.require(:user).permit(:name,:email,:message,
     pets_attributes: [:name, :email,:message])
  end

为了更好的方法,你可以只有一种方法:

def user_params
   params.require(:user).permit(:name,:email,:message,
     pets_attributes: [:name, :email,:message])
end

您可以只使用一种方法并在新建和编辑中重复使用,而不是为新建和编辑使用单独的过滤器方法。

只需保持干燥即可。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2017-01-18
    • 1970-01-01
    • 2018-11-05
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多