在我的模型中,我有:
class Listing < ApplicationRecord
...
has_rich_text :description
...
end
在我的seed.rb中:
@listing = Listing.new(
title: 'CODE VEIN',
price: 59.99 * 100,
description: "<p>#{Faker::Lorem.paragraphs(number: 30).join(' ')}</p>",
seller_id: seller.id,
release_date: Date.parse('Sep 26, 2019'),
status: :active,
esrb: 'MATURE'
)
Listing.description出现nil,导致我的NOT NULL约束出错。
我已经用pry调试过,并尝试使用@listing.description.body= text
或@listing.description.body = ActionText::Content.new(text)
,但两者仍然导致Listing#description为零。
这是一个仅API项目,但是我在前端react应用程序中使用Trix RTE。是否有一种特定的方法来丰富rich_text列?
答案 0 :(得分:1)
ActionText将实际内容存储在一个单独的action_text_rich_texts
表中,该表使用多态关联来链接回其附加到的模型。
# This migration comes from action_text (originally 20180528164100)
class CreateActionTextTables < ActiveRecord::Migration[6.0]
def change
create_table :action_text_rich_texts do |t|
t.string :name, null: false
t.text :body, size: :long
t.references :record, null: false, polymorphic: true, index: false
t.timestamps
t.index [ :record_type, :record_id, :name ], name: "index_action_text_rich_texts_uniqueness", unique: true
end
end
end
ActionText的JavaScript组件(实际上就是重点)在用户与Trix交互以创建/更新action_text_rich_texts
表中的行时自动发送AJAX请求,甚至在您保存记录之前,重新创建。
然后提交表单时,实际上是将ID提交给action_text_rich_texts
表上的行,而不是内容。然后,当您保存模型时,它将使用模型中的action_text_rich_texts
和record_type
更新record_id
上的相应行。这是一个非常尴尬的解决方案,其解决方案是不必在模型中添加列。
我真的看不到在API中使用ActionText的意义,因为整体意义在于向经典的Rails应用添加快速而肮脏的Trix实现。您确实应该只用一个文本列即可解决此问题。尤其是这样,您无需加入即可访问内容。
答案 1 :(得分:0)
您的代码还必须进行其他处理。也许,如果您共享迁移和完整的Listing类文件,则可能更容易发现正在发生的事情。
这里有几个步骤可确保您设置正确:
rails new testrichtext -d mysql --api
cd testrichclient
rake db:create
rails g model listing description:text
class CreateListings < ActiveRecord::Migration[6.0]
def change
create_table :listings do |t|
t.text :description, null: false
t.timestamps
end
end
end
rake db:migrate
rails c
在控制台内:
l = Listing.new(description: "<p>Something nice</p>")
l.save!
Listing.first.description
如您所见,这足以保存/添加带有富文本格式的新列表。因此,您可能正在进行的所有操作都应该通过添加不同的验证或回调来在其他地方引起。不查看整个文件就很难说