ruby-on-rails - Ruby on Rails - 如何使用 simple_form grouped_select 获得自定义输出?
问题描述
我正在使用 simple_formgrouped_select
但我没有得到我想要的输出。
楷模
class PartnerName < ApplicationRecord
has_many :urls, dependent: :destroy
end
#<PartnerName id: 1, name: "technology", app_name: "test">
#<PartnerName id: 2, name: "technology", app_name: "user">
class Url < ApplicationRecord
belongs_to :network_partner_name
end
#<Url id: 1, partner_name_id: 1, name: "abc.org">
#<Url id: 2, partner_name_id: 1, name: "qwe.org">
#<Url id: 3, partner_name_id: 2, name: "123.org">
#<Url id: 4, partner_name_id: 2, name: "345.org">
查看文件
= simple_form_for(:query, method: :post) do |f|
= f.error_notification
.form-row
.col-auto
= f.input :network_partner_name_id, collection: PartnerName.order(:name),
include_blank: false
.form-row
.col-auto
= f.input :url_id, collection: PartnerName.order(:name).includes(:urls),
as: :grouped_select,
group_method: :urls,
include_blank: false
输出
我用上面的形式得到了下面的输出。
对于合作伙伴名称
<option value="1">technology</option>
<option value="2">technology</option>
对于网址
<optgroup label="technology">
<option value="1">abc.org</option>
<option value="2">qwe.org</option>
</optgroup>
<optgroup label="technology">
<option value="3">123.org</option>
<option value="4">456.org</option>
</optgroup>
但我想用 ParnerName 的名称和 ParnerName 的 app_name 属性获得如下输出。我怎样才能做到这一点?
对于合作伙伴名称
<option value="1">technology - test</option>
<option value="2">technology - user</option>
对于网址
<optgroup label="technology - test">
<option value="1">abc.org</option>
<option value="2">qwe.org</option>
</optgroup>
<optgroup label="technology - user">
<option value="3">123.org</option>
<option value="4">456.org</option>
</optgroup>
谢谢你。
解决方案
您可以添加一个类方法PartnerName
class PartnerName < ApplicationRecord
has_many :urls, dependent: :destroy
def label_collection
"#{name} - #{app_name}"
end
end
并将其与label_method
和group_label_method
simple_form 助手一起使用:
= simple_form_for(:query, method: :post) do |f|
= f.error_notification
.form-row
.col-auto
= f.input : network_partner_name_id, collection: PartnerName.order(:name),
label_method: :label_collection,
include_blank: false
.form-row
.col-auto
= f.input :url_id, collection: PartnerName.order(:name).includes(:urls),
as: :grouped_select,
group_method: :urls,
group_label_method: :label_collection,
include_blank: false
推荐阅读
- quarkus - 使用 Quarkus 运行 Specs2
- video - 如何仅在不兼容的浏览器中播放 MP4 HEVC (h265) 视频文件时检测音频?
- python - 安装扩展 plotly jupyter lab 后出现 PermissionError
- c# - AutoCAD 2021 .NET API:获取数据库中的所有块引用?
- python - 我需要欺骗获取请求的 IP
- java - 如何从 Firebase 实时数据库中的两个不同子项获取订单数据?
- javascript - json_encode 适用于整数而不适用于字符串
- r - 将表格放入 r 笔记本中的 pdf 文档中
- python - python - 如何删除Python Pandas中某些列值中没有特定数量的数字的观察?
- hibernate - 如何在 Wildfly AS 中为 Hibernate 设置 Scanner 而不会遇到 ClassLoader 问题?