在Rails中,Helper指的是可以在Template中使用的辅助方法,主要用途是可以将资料转化成输出用的HTML字串,例如我们已经用过了Rails内建的link_to
方法,它可以将字串变成超连结。Rails还内建了许多Helper方法,可以让我们建构HTML更为容易。我们在一章中将介绍其中较为常用的几个方法。
另一个使用Helper的理由是可以简化Template中的复杂结构,将Template中较为复杂的程式都用Helper包装起来,最好让Template只包含单纯的变数以及最简单的条件逻辑和回圈,这样就算是不会程式的网页设计师,也能够轻易了解套版甚至修改Template样板。
因为Helper预设只能在Template中使用,如果想在rails console中呼叫,必须加上
helper
,例如helper.link_to
。另外,虽然机会不多,如果真的要在Rails Controller或Model程式中呼叫Helper,则可以加上ApplicationController.helpers
前置词。
使用Rails内建的静态档案(Assets)辅助方法有几个好处:
几个常用的方法:
将\n
换行字元换成HTML的<br>
标签
撷取前n个字元
白名单逸出
预设允许的HTML标签和属性如下:
ActionView::Base.sanitized_allowed_tags
=> #<Set: {"strong", "em", "b", "i", "p", "code", "pre", "tt", "samp", "kbd", "var" , "sub", "sup", "dfn", "cite", "big", "small", "address", "hr", "br", "div", "span", "h1", " h2", "h3", "h4", "h5", "h6", "ul", "ol", "li", "dl", "dt", "dd", "abbr", "acronym" , "a", "img", "blockquote", "del", "ins"}>
ActionView::Base.sanitized_allowed_attributes
=> #<Set: {"href", "src", "width", "height", "alt", "cite", "datetime", "title", "class", "name", "xml: lang", "abbr"}>
如果需要增加,可以在config/application.rb
中新增,例如:
config.action_view.sanitized_allowed_tags = %w[table tr td]
config.action_view.sanitized_allowed_attributes = "rel"
移除HTML标签
移除HTML超连结标签