Conditional HTML tag attribute in HAML
Let's say we want to add a class to a row in a table if a condition is given:
%tr{ row.name == "active" ? {class: "active"} : {}}
If the condition is true, the attribute class="active"
will be added to the tr
tag, otherwise nothing will be added.
It's that easy, but I had a hard time finding out the first time.
Written by Fernando Briano
Related protips
6 Responses
data:image/s3,"s3://crabby-images/d124f/d124f278f7daf80201731fbbba4fffefe8201df8" alt=""
I was just looking how to do this, thanks!
data:image/s3,"s3://crabby-images/4f560/4f560c65acede4253d765508c5a80abc1c6704e4" alt=""
Glad it helped. I t helps me every time I need to do this. I'll memorize it eventually... :P
data:image/s3,"s3://crabby-images/1f15e/1f15e5726903a1e91b3191a110bfde004e0a3906" alt=""
Great tip. Thanks!
data:image/s3,"s3://crabby-images/35ba8/35ba8a9d5cdfdef67a93db1044e25f631fcc4107" alt=""
I didn't know you could pass a Hash directly inside the brackets.
Thanks!
data:image/s3,"s3://crabby-images/8da94/8da94102b2032ffdd2bb29a72054946ce210e804" alt=""
Or you could do this like
%tr{class: ("active" if row.name == "active")}
That way you could also have other attributes besides the class
data:image/s3,"s3://crabby-images/7168e/7168ecb0d9847f5ee19194375e230391d4fee230" alt=""
@zinkkrysty
I was thinking the same as you before, but when you need several conditional attributes, it will get messy, like this:
%tr{ class: ("active" if row.name == "active"), title: ("active" if row.name == "active"), data-id = #{row.id} }
instead you can write it like this
%tr{ {data-id = #{row.id}}, row.name == "active" ? { class: "active", title: "active" } : { } }
unconditional attributes can be placed into different hash, and the two hashes will be flatten by haml, I think. And sorry that I don't know how to beautify my code in a block :D