我正在编写一个显示代码和输出的样式指南。它目前的结构使得代码只需要描述一次,并以原始版本和解释版本显示,如下所示:
<% code = <<PLACE_THE_EXAMPLE_CODE_BETWEEN_THESE_TWO_LINES_EXACTLY_AS_YOU_WANT_IT_TO_APPEAR
<div>
#{ image_tag 'image.png' }
</div>
PLACE_THE_EXAMPLE_CODE_BETWEEN_THESE_TWO_LINES_EXACTLY_AS_YOU_WANT_IT_TO_APPEAR
%>
<%= raw code %>
<%= content_tag :pre, code, class: "prettyprint linenums" %>
这很棒,而且相当容易维护。问题出现在 rails helpers 上,就像image_tag
上面的例子一样。视图示例正确显示了 div 中的图像,代码示例显示了相关的 HTML。在这种情况下,相关的 HTML 包含一个锚标记 -image_tag
方法的结果,而不是调用本身。
我更喜欢代码示例来显示辅助方法,而不是它们的结果。我可以通过在文件中指定示例代码并渲染或读取文件来完成这项工作。如上所述,我更愿意通过在变量中指定代码来完成这项工作,但我似乎无法让 ERB 分隔符在 erb 块内的字符串内工作。即使是最简单的情况<% foo = '<%= bar %>' %>
也根本不起作用。我尝试过使用官方文档中的详细信息(例如),<%% %%>
但没有取得多大成功。% %
我能找到的关于此事的唯一信息是here, using <%= "<" + "%=" %> link_to <%= image.css_tag.humanize %> <%= "%" + ">" %> %>
,这在这个用例中不起作用(如果有的话)。
那么,有没有办法在 ERB 字符串中指定一个包含 ERB 结束分隔符 ( %>
) 的字符串,还是我使用稍微笨拙的文件读取方法卡住了?谢谢!
编辑:
我想最终得到的是这个的工作版本:
<%# Idealized code - does not work %>
<% code = <<PLACE_THE_EXAMPLE_CODE_BETWEEN_THESE_TWO_LINES_EXACTLY_AS_YOU_WANT_IT_TO_APPEAR
<div>
<% image_tag 'image.png' %>
</div>
PLACE_THE_EXAMPLE_CODE_BETWEEN_THESE_TWO_LINES_EXACTLY_AS_YOU_WANT_IT_TO_APPEAR
%>
所以这<%= raw code %>
将(继续)输出:
<div>
<img src="/images/image.png" alt="Image" />
</div>
并<%= content_tag :pre, code, class: "prettyprint linenums" %>
会输出:
<pre class="prettyprint linenums">
<div>
<% image_tag 'image.png' %>
</div>
</pre>
而不是当前使用变量时所做的事情,即:
<pre class="prettyprint linenums">
<div>
<img src="/images/image.png" alt="Image" />
</div>
</pre>
我希望用户能够复制代码示例并将其粘贴到新视图中,而无需将 HTML 转换回生成它们的帮助程序。我认为我基本上需要的是一个替代的 ERB 分隔符,就像'
和"
(或什至%q{}
)为字符串而变化一样。似乎即使最终的 ERB 分隔符出现在字符串内部,它实际上也被作为块的结尾处理。最简单的例子在<% foo = '<%= bar %>' %>
某种程度上展示了我想要完成的事情。在生成器中,您可以使用<% foo = '<%%= bar %>' %>
(或类似的东西),告诉它不要立即作为 ERB 处理。这在从文件中读取时,甚至在纯 rb 文件(如助手)中都可以正常工作,但在这种情况下,将它放在视图中是最有意义的,因为它旨在由我们的设计师。