我正在使用bootstrap tags input来处理代码提交。我也在使用act-as-taggable-on。
在表单中输入信息可以正常工作。提交正确填写的表单有效。但是,如果验证失败,页面将使用以前的标记组合成单个标记进行渲染。
以下是提交前的一些HTML
<form action="/items" method="post">
<div class="bootstrap-tagsinput">
<span class="tag label label-info">
"foo"<span data-role="remove"></span>
</span>
<span class="tag label label-info">
"bar"<span data-role="remove"></span>
</span>
<span class="tag label label-info">
"foobar"<span data-role="remove"></span>
</span>
</div>
<input type="text" value name="item[tag_list]" id="item_tag_list" style="display: none;">
</form>
并且在验证失败后
<div class="bootstrap-tagsinput">
<span class="tag label label-info">
"foo bar foobar"<span data-role="remove"></span>
</span>
</div>
我的控制器:
def create
Item.transaction do
@item= Item.create(name: item_params[:name],
tag_list: item_params[:tag_list],
created_by: current_user.id,
status: Item::STATUS[:pending])
if @item.errors.empty?
@user_item = @item.user_items.build(user_id: current_user.id)
if @user_item.save
flash[:notice] = "Thank you for your item request! Your request will be processed within the next 5 days."
redirect_to items_path
else
render :new
raise ActiveRecord::Rollback, "UserItem create failed"
end
else
render :new
end
end
end
private
def item_params
params.require(:item).permit(:name, :tag_list)
end
end
我需要一种方法让这个参数显示为用户输入时的多个标签。
答案 0 :(得分:0)
当您使用逗号分隔的字符串设置tag_list时,它将成为字符串数组。如果验证失败,我需要将tag_list属性设置为一串标签。这两行有助于我实现这一目标。
@item.tag_list.remove(item_params[:tag_list], parse: true)
@item.tag_list.add(item_params[:tag_list])