0

www.leapfm.com にアクセスすると、各曲の右側の括弧内に YouTube の URL が表示されます。フィードバックを評価した後、代わりに括弧内にジャンル タグを表示することにしました。

これをやろうとすると、

次のエラーが表示されます。

Couldn't find Genre without an ID
Extracted source:

def genre_name
@genre = Genre.find(params[:id])
end
def get_last_song

song_controller スニピット

def index
      if params[:query].present? 
      @songs = Song.search(params)
      get_last_song
      genre_name
    elsif params[:genre]
      @songs = Song.tagged_with(params[:genre]).paginate(:page => params[:page], :per_page => 15)
      get_last_song
      genre_name
    else      
      @songs = Song.order('id').order('plusminus desc nulls last').paginate(:page => params[:page], :per_page => 15) 
      #@songs = Song.tally.paginate(:page => params[:page], :per_page => 15)
      get_last_song
      genre_name
    end
  end

  def genre_name
    @genre = Genre.find(params[:id])
  end

index.html.erb (_song 部分) スニピット

<div class="title">
  <%=link_to image_tag('arrow.gif'), vote_for_song_path(song), :remote => true, :method => :put  if controller.action_name == "index" %>
  <%= link_to song.title, song %><span class="subtext"> (<%= song.genre_name %>)</span>
</div>

song.rb の抜粋:

class Song < ActiveRecord::Base

acts_as_voteable

  belongs_to :user
  has_many :comments, :dependent => :destroy
  has_many :genre_songs
  has_many :genres, through: :genre_songs

ジャンル.rb

class Genre < ActiveRecord::Base
  has_many :genre_songs, :dependent => :destroy
  has_many :songs, through: :genre_songs

end

スキーマ スニピット

 create_table "genre_songs", force: true do |t|
    t.integer  "genre_id"
    t.integer  "song_id"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  add_index "genre_songs", ["genre_id"], name: "index_genre_songs_on_genre_id", using: :btree
  add_index "genre_songs", ["song_id"], name: "index_genre_songs_on_song_id", using: :btree

  create_table "genres", force: true do |t|
    t.string   "name"
    t.datetime "created_at"
    t.datetime "updated_at"
  end

  create_table "songs", force: true do |t|
    t.string   "title"
    t.string   "artist"
    t.text     "url"
    t.string   "track_file_name"
    t.string   "track_content_type"
    t.integer  "track_file_size"
    t.datetime "track_updated_at"
    t.integer  "user_id"
    t.datetime "created_at"
    t.datetime "updated_at"
    t.integer  "plusminus"
  end
4

1 に答える 1