Global and Scoped CSS in Vue

In this video I want to talk about writing css in Vue because it gives us our of the box the possibility to write isolated css.

In previous video we successfully created our UsersList component and rendered our data inside. But how we can style our component? For this in Vue we have a stype part inside our component. Let's create a new class for each user and add it.

<div v-for="user in users" :key="user.id" class="user">{{ user.name }}</div>

<style>
.user {
  border: 1px solid red;
}
</style>

As you can see it looks almost like plain css. If we check in browser there is a global class user that is applied to our element. This is how you can write global styles in Vue and this is how I never recommend to write styles.

What we want to do is writing our styles in isolation. Now if we create other component and .user class inside, we will get an override of the class because our styles are global. And this is the huge problem of css. To avoid this problem Vue allows us to make our css isolated and only valid for this component.

To achieve that we need to add scoped attribute to our styles section.

<style scoped>
.user {
  border: 1px solid red;
}
</style>

As you can see everything is working as before but we have a special class notation now. There is an attribute which helps this class to become unique. This is just some unique id which is generated by Vue and we don't see it in the code at all. But now we simply write styles as always and we should not think if our styles are unique or will we have name collisions at all.

This is why I always recommend you to put scoped attribute in every component and never ever write global styles because normally you can implement any Vue project just with scoped styles.

Now let's add some nice styling for our users.

.user {
  font-size: 18px;
  border-bottom: 1px solid grey;
  padding: 10px;
  display: flex;
  justify-content: space-between;
}

As you can see Vue gives a possibility to work with CSS in easy and isolated way. Just don't forget to put scoped attribute in your every component and you are good to go.

Want to conquer your next JavaScript interview? Download my FREE PDF - Pass Your JS Interview with Confidence and start preparing for success today!

📚 Source code of what we've done
Did you like my post? Share it with friends!
Don't miss a thing!
Follow me on Youtube, Twitter or Instagram.
Oleksandr Kocherhin
Oleksandr Kocherhin is a full-stack developer with a passion for learning and sharing knowledge on Monsterlessons Academy and on his YouTube channel. With around 15 years of programming experience and nearly 9 years of teaching, he has a deep understanding of both disciplines. He believes in learning by doing, a philosophy that is reflected in every course he teaches. He loves exploring new web and mobile technologies, and his courses are designed to give students an edge in the fast-moving tech industry.