我有一个很大的注册表格,所以我只是给你看一个“小”的部分。
<div class="input-element uk-margin-small-bottom uk-flex">
<% if @user.errors[:first_name].any? %>
<div class="uk-inline uk-width-1-2" title="<%= @user.errors[:first_name].first %>" uk-tooltip="pos: left">
<span class="uk-form-icon" uk-icon="icon: user"></span>
<%= f.text_field :first_name, placeholder: "First name", class: "uk-input uk-form-danger" %>
</div>
<% else %>
<div class="uk-inline uk-width-1-2">
<span class="uk-form-icon" uk-icon="icon: user"></span>
<%= f.text_field :first_name, placeholder: "First name", class: "uk-input" %>
</div>
<% end %>
</div>这是的逻辑,每个输入的和模式是相同的:
它为相同的通用机制带来了大量的HTML / Ruby代码。我知道Rails提供了一些帮助程序来简化某些场景中的代码。
我的问题能用帮手解决吗?如果可以的话,你觉得我该怎么处理呢?
谢谢,
发布于 2017-08-18 22:20:42
我想说的是,你可能是在追求partial,而不是helper。
我会制作一个名为eg:_form_field.html.erb的部分,内容如下:
<div class="input-element uk-margin-small-bottom uk-flex">
<%
if model.errors[:field].any?
title = model.errors[:field].first
tooltip = 'pos: left'
input_extra_class = 'uk-form-danger'
else
title = ''
tooltip = ''
input_extra_class = ''
end
%>
<div class="uk-inline uk-width-1-2" title="<%= title %>" uk-tooltip="<%= tooltip %>">
<span class="uk-form-icon" uk-icon="icon: user"></span>
<%= f.text_field :field, placeholder: label, class: "uk-input <%= input_extra_class %>" %>
</div>
</div>然后称之为:
<%= render 'form_field', model: @users, field: :first_name, label: 'First name' %>请注意,在这个部分中,我提取了一些变化为if-语句的比特,以避免重复不变化的html标记。这是可选的。如果你想的话,你可以把它留着。但是,无论哪种方法,都要将model、field和label作为局部变量传递到其中的部分位置。
下面是关于partials的rails文档:rendering.html#using-partials
发布于 2017-08-18 22:37:58
我认为一个部分可能更干净,但你仍然需要一个助手,也许是这样的:
Helper
def my_text_field(errors, element)
div_options = { class: "uk-inline uk-width-1-2" }
input_class = "uk-input"
if errors.any?
div_options.merge(title: errors.first, "uk-tooltip": "pos: left")
input_class << " uk-form-danger"
end
content_tag(:div, div_options) do
content_tag(:span, class: "uk-form-icon", "uk-icon": "icon: user") do
element.text_field :first_name, placeholder: "First name", class: input_class
end
end
end视图
<div class="input-element uk-margin-small-bottom uk-flex">
<%= my_text_field(@user.errors[:first_name], f) %>
</div>https://stackoverflow.com/questions/45765624
复制相似问题