Jade Inline Conditional

后端 未结 7 1624
你的背包
你的背包 2021-01-31 15:43

I\'m trying to make everything apart from the first element in an array have a CSS class using the Jade templating engine.

I was hoping I could do it like this, but no l

相关标签:
7条回答
  • 2021-01-31 16:11

    With pug 2 you can use this syntax:

    a(href='/', class="link", class={"-active": page === 'home'}) Home page
    

    more here: https://pugjs.org/language/attributes.html

    0 讨论(0)
  • You can to use, not only class, but a bunch of attributes in a conditional way:

    - each sense, i in entry.senses
      - var attrs = i === 0 ? {'disabled': 'true'} : {'class': '100', 'ng-model': 'vm.model.name', 'ng-click': 'vm.click()'}
      div&attributes(attrs)
    
    0 讨论(0)
  • 2021-01-31 16:25

    This is my solution. I'm using a mixin to pass the current active path and in the mixin I define the complete menu and always pass an if to check if the path is the active path.

    mixin adminmenu(active)
      ul.nav.nav-list.well
        li.nav-header Hello
        li(class="#{active=='/admin' ? 'active' : ''}")
          a(href="/admin") Admin
    
    0 讨论(0)
  • 2021-01-31 16:26

    You can do this instead:

    - each sense, i in entry.senses
      - var klass = (i === 0 ? 'span13' : 'span13 offset3')
      div(class=klass)
        ... a tonne of subsequent stuff
    
    0 讨论(0)
  • 2021-01-31 16:30

    I prefer to use simple functions to check any complex conditions. It's works perfect and fast, you shouldn't write long lines in template. Can replace this

    - each sense, i in entry.senses
      - var klass = (i === 0 ? 'span13' : 'span13 offset3')
      div(class=klass)
        ... a tonne of subsequent stuff
    

    to this

    -function resultClass(condition)
     -if (condition===0)
      -return 'span13'
     -else if (condition===1)
      -return 'span13 offset3'
     -else if (condition===2) //-any other cases can be implemented
      -return 'span13 offset3'
     -else
      -return 'span13 offset3'
    
    - each sense, i in entry.senses
      div(class=resultClass(i))
        ... a tonne of subsequent stuff
    

    Hope it helps and the idea is clear to understand.

    Also it's good practice to move all functions in include file and share it between different templates, but it's another question

    0 讨论(0)
  • 2021-01-31 16:33

    This also works:

    div(class=(i===0 ? 'span13' : 'span13 offset3'))
    
    0 讨论(0)
提交回复
热议问题