我想为一些 html 元素动态创建属性。
在我的情况下,我想根据user.role
.
因此,如果user
有权编辑某些字段,我不想在元素上放置禁用属性。否则,我确实想要它。
我知道我可以用这些方法做到这一点:
- 方法 1 - 使用条件
if (user.role === 1)
input(type='text', name='foo')
else
input(type='text', name='foo', disabled)
- 方法 2 - 纯 HTML
- var disabledAttr = (user.role === 1) ? "disabled" : "";
| <input type="text" name="foo" #{ disabledAttr} />
方法 1 不好,因为我需要重复一些代码。使用方法 2 我不需要重复代码,但我必须使用纯 HTML 而不是 Jade 标记。
我试过这样的事情:
input(type='text', name='foo', #{ disabledAttr} )
但是jade生成如下代码:
<input type="text" name="foo" disabledattr="" />
有更好的主意吗?