gpt4 book ai didi

mysql - 具有连接表关系的事件管理

转载 作者:行者123 更新时间:2023-11-29 17:53:40 26 4
gpt4 key购买 nike

我正在配置事件管理。除了连接表之外,一切都在运行,连接表将杂志资源与关键字资源连接起来。一本杂志由多个关键字定义,一个关键字可以定义多本杂志。

我有两个模型:

### models/magazine.rb

class Magazine < ActiveRecord::Base
attr_accessible :colour, :cover_alt, :description, :number, :short, :title_id

has_and_belongs_to_many :keywords, :join_table => "magazines_keywords"
belongs_to :title, :class_name => "Keyword", :foreign_key => "title_id"
end


### models/keywords.rb

class Keyword < ActiveRecord::Base
attr_accessible :word, :description

has_and_belongs_to_many :magazines, :join_table => "magazines_keywords"
end

和一个连接表:

### models/magazines_keyword.rb
class MagazinesKeyword < ActiveRecord::Base
attr_accessible :magazine_id, :keyword_id

belongs_to :magazine
belongs_to :keyword
end

此设置适用于我的 Rails 应用程序的 View ,并且我的 AA 杂志资源的索引和显示部分可以正常工作,但表单(用于新建和编辑)不起作用:

ActiveAdmin.register Magazine do
menu :priority => 1

form do |f|
f.semantic_errors *f.object.errors.keys
f.inputs "Magazine Details" do
f.input :title_id, :label => 'Title', :as => :select, :collection => Keyword.all.map{ |u| ["#{u.word.capitalize}", u.id] }
f.inputs :magazines_keywords do
f.has_many : magazines_keywords do |s|
s.input :keyword, :as => :select, :multiple => true, :collection => MagazinesKeyword.all.map { |u| ["#{u.keyword.word.capitalize}", u.id] }
end
end
end
f.actions
end

show do
panel "Magazine Details" do
attributes_table_for magazine do
row "Keywords", :keyword do |m|
m.keywords.map { |d| d.word }.join(", ").html_safe
end
end
end
active_admin_comments
end
end

运行应用程序时,我得到 NoMethodError in Admin/magazines#edit

哪里/active_admin/resource/edit.html.arb line #1加薪undefined method 'klass' for nil:NilClass

我可以使用以下方式显示表单部分中的所有关键字:

f.input :magazines_keywords, :as => :check_boxes, :multiple => true, :collection => MagazinesKeyword.all.map{ |u| ["#{u.keyword.word.capitalize}", u.id] }

但是当我尝试编写它们时,它不起作用。编辑值也不起作用。

我哪里遗漏了什么?我怎样才能让它工作?

****更新****

经过一些工作,我得到了以下解决方案:

form do |f|
f.semantic_errors *f.object.errors.keys
f.inputs "Saft Details" do
f.input :title_id, :label => 'Title', :as => :select, :collection => Keyword.all.map{ |u| ["#{u.word.capitalize}", u.id] }
f.input :keywords, :as => :check_boxes, :input_html => {:multiple => true}
end
f.actions
end

按照建议:

f.input :keywords, :as => :check_boxes, :input_html => {:multiple => true} do
f.has_many :keywords do |s|
s.input :keyword, :collection => Keyword.all.map { |kw| ["#{kw.word.capitalize}", kw.id] }
end
end

使用这两种解决方案,我都可以编写新的杂志条目并将关联写入连接表,不幸的是它显示 #<Keyword:0x10c858858>以形式而非文字。我错过了什么?

最佳答案

ActiveAdmin 非常聪明,能够理解您想要做什么。因此,您应该忽略 MagazinesKeyword 并直接进入 Keyword 模型。所以你应该改变这个:

f.has_many :magazines_keywords do |s|
s.input :keyword, :as => :select, :multiple => true, :collection => MagazinesKeyword.all.map { |u| ["#{u.keyword.word.capitalize}", u.id] }
end

这样:

f.has_many :keywords do |s|
s.input :keyword, :as => :select, :multiple => true, :collection => Keyword.all.map { |kw| ["#{kw.word.capitalize}", kw.id] }
end

活跃管理员将自行处理MagazinesKeyword

关于mysql - 具有连接表关系的事件管理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49068308/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com