0

嗨,我目前正在尝试建立一个附有许多用户的相册,并且我正在尝试修复它们之间的关系,以便它是多对多的(一个用户 + 多个相册,一个相册 + 多个用户)。但是,我在触摸模型和迁移后尝试加载 show.html.erb 时收到错误消息。请帮忙!!

错误:

uninitialized constant User::UserAlbum

显示.html.erb

<% provide(:title, "Welcome, #{@user.name}!") %>

<div>
    You currently have <%= pluralize(@user.albums.count, "album") %>
</div>

<div>
    <%= link_to "Create a new album!", new_user_album_path(@user) %>
</div>

<div>
<% if @user.albums.any? %>
hey
<% else %>
boo
<% end %> 
</div>

<%= link_to "Back", users_path %>

专辑模特

class Album < ActiveRecord::Base
  attr_accessible :avatar, :name, :description
  has_many :user_albums
  has_many :users, :through => :user_albums
  has_many :photos
end

用户模型

class User < ActiveRecord::Base

  has_secure_password
  attr_accessible :email, :name, :password, :password_confirmation
  validates_presence_of :password, :on => :create

  validates_format_of :name, :with => /[A-Za-z]+/, :on => :create
  validates_format_of :email, :with => /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i, :on => :create
  validates_length_of :password, :minimum => 5, :on => :create

  has_many :user_albums
  has_many :albums, :through => :user_albums
  accepts_nested_attributes_for :albums

end

照片模型(可能没必要看这个)

class Photo < ActiveRecord::Base
  belongs_to :album
end

user_albums 模型

class UserAlbums < ActiveRecord::Base
 belongs_to :album
 belongs_to :user
end

图式

ActiveRecord::Schema.define(:version => 20121001160745) do

create_table "albums", :force => true do |t|
  t.string   "name"
  t.datetime "created_at",  :null => false
  t.datetime "updated_at",  :null => false
  t.string   "description"
end

create_table "photos", :force => true do |t|
  t.string   "avatar_file_name"
  t.string   "avatar_content_type"
  t.integer  "avatar_file_size"
  t.datetime "avatar_updated_at"
  t.datetime "created_at",          :null => false
  t.datetime "updated_at",          :null => false
  t.integer  "album_id"
end

create_table "user_albums", :force => true do |t|
  t.datetime "created_at", :null => false
  t.datetime "updated_at", :null => false
  t.integer  "user_id"
  t.integer  "album_id"
end

create_table "users", :force => true do |t|
  t.string   "name"
  t.string   "email"
  t.datetime "created_at",      :null => false
  t.datetime "updated_at",      :null => false
  t.string   "password_digest"
end

结尾

用户控制器

类用户控制器 < 应用控制器

    def index
      @users = User.all

      respond_to do |format|
        format.html
        format.json { render json: @users }
      end
    end

    def new
      @user = User.new

      respond_to do |format|
        format.html # new.html.erb
        format.json { render json: @user }
      end
    end 

    def create
      @user = User.new(params[:user])

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

    def show
      @user = User.find(params[:id])
    end

    def update
      @user = User.update_attributes(params[:user])
      if @user.save
        format.html { redirect_to @user, notice: 'User successfully updated.'}
        format.json { render json: @user, status: :created, location: @user }
      else
        format.html { render action: 'edit' }
        format.json { render json: @user.errors, status: :unprocessable_entity }
      end
    end

end

解决方案:我的 UserAlbums 模型是复数而不是 UserAlbum。

4

1 回答 1

0

你有UserAlbum模特吗?

如果没有 - 您需要创建一个以使您的关联有效。

class UserAlbum < ActiveReocrd::Base
  belongs_to :user
  belongs_to :album
end
于 2012-10-01T16:32:01.613 回答