In your working example the end
line is being treated as raw text, and will be included in your output. This works because you effectively don’t have an end
keyword. If you change this line to - end
— i.e. add the hyphen (and make sure you’ve got your indentation correct) — you’ll see an error like:
Syntax error on line 9: You don't need to use "- end" in Haml. Un-indent to close a block:
- if foo?
%strong Foo!
- else
Not foo.
%p This line is un-indented, so it isn't part of the "if" block
Note that Haml doesn’t always disallow end
keywords, only end
by itself. You can use them with statement modifiers, e.g.:
- @things.each do |thing|
%p= thing.to_s
-end unless @dont_show_things
or if you want to make use of the result of the block:
= @things.map do |thing|
- do_something_with(thing)
-end.join(",")
As for using {}
, you can’t. When Haml compiles the template to Ruby the hardcoded string end
is added to close any blocks as needed. It could be possible to modify Haml to be able to use do..end
or {}
, but the extra complexity probably isn’t worth it. This way is a better fit with the common Ruby idiom of using do...end
for multiline blocks, and {}
for single line ones.
If you need to use {}
because of some issue with operator precedence it might be a sign to create a helper method. Your Haml templates (or templates in any language) aren’t the best place for complex logic, it’s best to move it into real Ruby files.