I am looking for a solution to add "optional chaining" on PugJS to set data-active="true"
if i === 0
.
Bellow is my current code. This code is working, but the problem with this approach (bellow) is that I have to repeat my code on a else
statement and that doesn't make sense. I have to add (i === 0 ? 'data-active="true"' : '')
on the .my__element
, but I don't know how to do it.
if (i === 0)
.my__element(data-month=months[month] data-active="true")
else
.my__element(data-month=months[month])
Any help please? Thank you
Attribute values in Pug are "just regular JavaScript," as mentioned on the Attributes page on Pug docs.
If an attribute's value is false
, Pug doesn't print the attribute at all. This can be seen in the Boolean Attributes section on the same page:
// Input (Pug):
input(type='checkbox' checked)
input(type='checkbox' checked=true)
input(type='checkbox' checked=false)
input(type='checkbox' checked="true")
// Output (HTML):
<input type="checkbox" checked="checked" />
<input type="checkbox" checked="checked" />
<input type="checkbox" />
<input type="checkbox" checked="true" />
So, you can use i === 0 && "true"
as the value for the data-active
attribute:
.my__element(data-month=months[month] data-active=(i === 0 && "true"))
The parentheses around the attribute's value are optional, but they improve readability. So this is OK but less readable:
.my__element(data-month=months[month] data-active=i === 0 && "true")
A more verbose alternative:
.my__element(data-month=months[month] data-active=(i === 0 ? "true" : false))
.my__element(data-month=months[month] data-active=i === 0 ? "true" : false)
(Note that "true"
is a string and false
is a boolean; this is on purpose. You can try to switch their types to see why.)