简体   繁体   中英

Vue.js dynamic classes

I have some html using Vue.js here:

<div id="app">
  <ul class="navbar-nav">
      <li class="nav-item" v-for="tab in tabs">
          <a href="#" class="nav-link">{{ tab.name }}</a>
      </li>
  </ul>
</div>

I have the javascript here:

var app = new Vue({
  el: '#app',
  data: {
      tabs: [
        { name: "Home", active: "" },
        { name: "Challenges", active: "active" },
        { name: "Scoreboard", active: "" },
        { name: "About", active: "" }
    ]
  }
});

I want to set class to tabs.active since I'm using bootstrap. How can I do that?

Add

 v-bind:class="tab.active"

So your code should look like this:

 var app = new Vue({ el: '#app', data: { tabs: [{ name: "Home", active: "" }, { name: "Challenges", active: "active" }, { name: "Scoreboard", active: "" }, { name: "About", active: "" } ] } });
 <script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.17/vue.js"></script> <div id="app"> <ul class="navbar-nav"> <li class="nav-item" v-for="tab in tabs" v-bind:class="tab.active"> <a href="#" class="nav-link">{{ tab.name }}</a> </li> </ul> </div>

Use a class binding like this:

<li class="nav-item" :class="{active: tab.active === 'active'}" v-for="tab in tabs">

 new Vue({ el: '#app', data: { tabs: [ { name: "Home", active: "" }, { name: "Challenges", active: "active" }, { name: "Scoreboard", active: "" }, { name: "About", active: "" } ] } });
 .active .nav-link { color: white; background: blue; }
 <script src="https://unpkg.com/vue@2.5.17"></script> <div id="app"> <ul class="navbar-nav"> <li class="nav-item" :class="{active: tab.active === 'active'}" v-for="tab in tabs"> <a href="#" class="nav-link">{{ tab.name }}</a> </li> </ul> </div>

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM