How to Dynamically Bind CSS Classes In Vue?

8 minutes read

To dynamically bind CSS classes in Vue, you can use the v-bind directive along with the class attribute. The v-bind directive allows you to bind data dynamically to an HTML attribute.


Firstly, create a class object in the Vue component data or computed properties. This object will hold the names of CSS classes you want to apply dynamically. For example:

1
2
3
4
5
6
7
8
data() {
  return {
    classObject: {
      red: true, // will apply the 'red' CSS class
      bold: false // will not apply the 'bold' CSS class
    }
  };
}


In the HTML template, use the v-bind:class directive to dynamically bind the classes based on the properties of the class object. For example:

1
<div v-bind:class="classObject">Dynamic CSS classes</div>


In this case, the red class will be applied because it is set to true in the class object. The bold class will not be applied because it is set to false.


You can also dynamically bind classes based on a conditional statement. In such cases, you can use inline expressions within the v-bind:class directive. For example:

1
<div v-bind:class="{ red: isRed, bold: isBold }">Conditional classes</div>


Here, the isRed and isBold properties are expected to be boolean values that determine whether the respective CSS classes should be applied or not, based on the condition.


That's how you can dynamically bind CSS classes in Vue using the v-bind directive and the class attribute.

Best Vue.js Books to Read in 2025

1
Vue.js in Action

Rating is 5 out of 5

Vue.js in Action

2
Vue.js 3 Cookbook: Discover actionable solutions for building modern web apps with the latest Vue features and TypeScript

Rating is 4.9 out of 5

Vue.js 3 Cookbook: Discover actionable solutions for building modern web apps with the latest Vue features and TypeScript

3
Front-End Development Projects with Vue.js: Learn to build scalable web applications and dynamic user interfaces with Vue 2

Rating is 4.8 out of 5

Front-End Development Projects with Vue.js: Learn to build scalable web applications and dynamic user interfaces with Vue 2

4
Vue.js 3 By Example: Blueprints to learn Vue web development, full-stack development, and cross-platform development quickly

Rating is 4.7 out of 5

Vue.js 3 By Example: Blueprints to learn Vue web development, full-stack development, and cross-platform development quickly

5
Vue.js: Up and Running: Building Accessible and Performant Web Apps

Rating is 4.6 out of 5

Vue.js: Up and Running: Building Accessible and Performant Web Apps

6
Hands-on Nuxt.js Web Development: Build universal and static-generated Vue.js applications using Nuxt.js

Rating is 4.5 out of 5

Hands-on Nuxt.js Web Development: Build universal and static-generated Vue.js applications using Nuxt.js

7
Jump Start Vue.js

Rating is 4.4 out of 5

Jump Start Vue.js


What is the v-bind:class.exact directive in Vue?

The v-bind:class.exact directive is a directive in Vue.js that allows binding a class to an element conditionally. It is used to add or remove a class to/from an element based on whether or not a certain expression evaluates to true.


The .exact modifier is used in conjunction with v-bind:class to ensure that the class is added or removed in an exact manner. This means that the bound class will not be affected by other classes already present on the element.


Here's an example usage of v-bind:class.exact:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
<template>
  <div v-bind:class.exact="isActive ? 'active' : ''">Sample Element</div>
</template>

<script>
export default {
  data() {
    return {
      isActive: true
    }
  }
}
</script>


In the above example, the isActive data property will determine whether the active class is added to the <div> element. If isActive is true, the class active will be added; otherwise, it will be removed. The .exact modifier ensures that only the exact class specified in the binding is affected.


What is the v-bind directive in Vue?

The v-bind directive in Vue is used to bind the value of an HTML attribute or a component property to a data property in Vue's instance. It is a way to dynamically update the value of an attribute or property based on the data in Vue.


The syntax for v-bind is v-bind:attribute="dataProperty", where attribute is the name of the HTML attribute or component property, and dataProperty is the Vue data property to which the value is bound.


For example, <a v-bind:href="url">...</a> would bind the value of url data property to the href attribute of the <a> tag, and any changes in the url data property will automatically update the href attribute.


The v-bind directive can also be used in shorthand form as :attribute, where attribute is the name of the HTML attribute or component property. For example, <a :href="url">...</a> is equivalent to <a v-bind:href="url">...</a>.


How to conditionally apply CSS classes based on route in Vue?

To conditionally apply CSS classes based on the route in Vue, you can use the v-bind:class directive in your template. Here's an example of how to do it:

  1. Install Vue Router if you haven't already:
1
npm install vue-router


  1. Set up your routes and create an instance of Vue Router in your main.js file:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
import Vue from 'vue'
import VueRouter from 'vue-router'
import App from './App.vue'

Vue.use(VueRouter)

const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About }
]

const router = new VueRouter({
  routes
})

new Vue({
  router,
  render: h => h(App)
}).$mount('#app')


  1. In your template, use the v-bind:class directive with a computed property to conditionally apply CSS classes based on the route:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<template>
  <div>
    <div id="navbar" :class="navbarClass"></div>
    <router-view></router-view>
  </div>
</template>

<script>
export default {
  computed: {
    navbarClass() {
      return {
        'navbar-home': this.$route.path === '/',
        'navbar-about': this.$route.path === '/about'
      }
    }
  }
}
</script>

<style scoped>
.navbar-home {
  background-color: red;
}

.navbar-about {
  background-color: blue;
}
</style>


In this example, we have a computed property called navbarClass that returns an object with CSS class names as keys and the condition to check the current route path as values. The class names will be dynamically applied to the navbar element based on which route is active.


Note the use of the scoped attribute in the style block. This ensures that the CSS rules only apply to components consuming the style block, and not globally.

Facebook Twitter LinkedIn Telegram

Related Posts:

To bind data to the DOM in Vue.js, you can utilize Vue&#39;s data binding syntax and directives. This allows you to establish a connection between the data in your Vue instance and the DOM elements in your template.To bind data from your Vue instance to the DO...
In Vue.js, routing can be set up to navigate between different pages within a single-page application. To implement routing in a Vue.js application, you need to follow a set of steps:Install the Vue Router package via npm or yarn by running the following comma...
To create a new Vue instance, follow these steps:First, include the Vue library in your HTML file. You can do this by including the Vue CDN script tag: Define a new HTML element where you want to mount your Vue instance: Create a new Vue instance by calling th...