Say I have a things resource with a view helper method such as:
module ThingsHelper
def foo
ret = ""
3.times { ret += content_tag(:li, "foo") }
content_tag(:ul, ret)
end
end
This, then, is used in a template:
%p
= foo
The HTML source that's generated looks like this:
<!DOCTYPE html>
<html>
<head>
<title>Foo</title>
</head>
</html>
<body>
<p>
<ul><li>foo</li><li>foo</li><li>foo</li></ul>
</p>
</body>
As you can see, the helper output is not indented as the rest of the code. Any way to remedy this?
Try out the haml_tag
helper method provided with Haml. It's like content_tag
in some ways, but it outputs properly indented HTML. The main difference is that it outputs directly to the template, rather than returning a string. For example:
module ThingsHelper
def foo
haml_tag :ul do
3.times { haml_tag(:li, "foo") }
end
end
end
(As a side note, it's considered very bad Ruby style to use something other than two spaces for indentation).
I doubt it - at least not without a significant amount of mucking around.
Your = foo
is simply printing what is returned by your foo
helper - it's not getting parsed by haml. And you can't write haml in your helper method either.
The simplest way I can think of to deal with this is to just add literal whitespace characters in your helper (ie \n
and \t
).
You could also require
the relevant haml class(es) in your helper and call the parsing methods manually on ret
, but this is probably more complicated than worthwhile.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With