A switch allows a user to choose between two distinct values.
You can use them in place of a checkbox in your UI.
In this article, we’re going to learn about the Vuetify switch component and the different ways of customizing it.
The v-switch
component
v-switch
is the name of the component Vuetify provides for creating a switch:
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch></v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
};
</script>
data:image/s3,"s3://crabby-images/86998/869987406838fba72f597d73436f4b2f1f9cc375" alt="A switch turned off."
Clicking the switch turns it on:
data:image/s3,"s3://crabby-images/1d72f/1d72feab8ae295a2cd3b482878c09264799bb600" alt="A switch turned on."
Two-way binding with v-model
We can set up a two-way binding between the value of the switch and a variable with v-model
. In the code below, we’ve created a switch and a button below it for turning it off. We added a click handler to the button that will set switch1
to false
, which will turn the switch off due to the v-model
. The two-way binding
also ensures that toggling the switch in the user interface will update switch1
.
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch v-model="switch1"></v-switch>
</div>
<div class="d-flex justify-center mt-2">
<v-btn color="primary" @click="switch1 = false">Turn off</v-btn>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
data: () => ({
switch1: false,
}),
};
</script>
data:image/s3,"s3://crabby-images/f92ce/f92cef4f35036417ff8a734deb2db86feb347dc0" alt="A switch and a button to turn it off."
Clicking the button turns off the switch:
data:image/s3,"s3://crabby-images/0eb77/0eb779b4ab8dacce7cd4a7caabb52f63ef0e2b0f" alt="Clicking the button turns off the switch:"
Switch labels
We can explain the function of a switch to users with the label
prop:
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch
v-model="switch1"
:label="`Switch: ${switch1 ? 'on' : 'off'}`"
></v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
data: () => ({
switch1: false,
}),
};
</script>
data:image/s3,"s3://crabby-images/6c01c/6c01ced4474beb1c8be793f998fee93a9d99fbbf" alt="A turned off switch with a label."
data:image/s3,"s3://crabby-images/0435b/0435b085ed16ff5f925aeaa2173f34cbbfcfb04b" alt=""
Custom HTML labels
To include HTML in the label of a switch, use the label
slot:
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch v-model="switch1">
<template v-slot:label>
Switch:
<b :class="{ 'primary--text': switch1 }">{{
switch1 ? 'on' : 'off'
}}</b>
</template>
</v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
data: () => ({
switch1: false,
}),
};
</script>
data:image/s3,"s3://crabby-images/10746/10746a6f8fe3d98d232c4d18e843f73649e3d3c9" alt=""
data:image/s3,"s3://crabby-images/807e8/807e890449cd2b75bab24585d58afa56e5368aac" alt=""
Custom colors
Like many other Vuetify components, v-switch
comes with the color
prop which allows us to set a custom color:
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-col sm="4" class="d-flex justify-center"
><v-switch color="red" label="red"></v-switch>
</v-col>
<v-col sm="4" class="d-flex justify-center"
><v-switch color="primary" label="primary"></v-switch>
</v-col>
<v-col sm="4" class="d-flex justify-center"
><v-switch color="green" label="green"></v-switch>
</v-col>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
};
</script>
data:image/s3,"s3://crabby-images/87eea/87eeafdc54d083345b7fbb591ea8af602d8d33ba" alt="Switch components with custom colors."
Flat switch
We can use the flat prop to remove the elevation on the thumb of a switch.
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch
v-model="switch1"
:label="`Switch: ${switch1 ? 'on' : 'off'}`"
flat
></v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
data: () => ({
switch1: false,
}),
};
</script>
data:image/s3,"s3://crabby-images/82c04/82c0466c74169c5a87eab6ffa2f7fbdb0ebbe912" alt="A flat switch turned off."
data:image/s3,"s3://crabby-images/0020f/0020febd95feb54f0d34fbbde799a43560ca4679" alt="A flat switch turned on."
Switch in inset mode
To render a switch in inset mode, set the inset
prop to true
:
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch
v-model="switch1"
:label="`Switch: ${switch1 ? 'on' : 'off'}`"
inset
></v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
data: () => ({
switch1: false,
}),
};
</script>
data:image/s3,"s3://crabby-images/37a51/37a512204c86802f6855ec048d75a9406013a39c" alt="A turned off switch in inset mode."
data:image/s3,"s3://crabby-images/a57ed/a57ed6353f75ae0b773850d09bb0bef44d9d7cc7" alt="A turned on switch in inset mode."
Pass array to v-model
We can pass a shared array variable to the v-model
s of multiple switch components.
<template>
<v-app>
<div class="d-flex justify-center mt-2">
{{ people }}
</div>
<div class="d-flex justify-center mt-2">
<v-switch
v-model="people"
color="primary"
label="Peter"
value="Peter"
></v-switch>
</div>
<div class="d-flex justify-center mt-2">
<v-switch
v-model="people"
color="primary"
label="Daniel"
value="Daniel"
></v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
data: () => ({
people: [],
}),
};
</script>
data:image/s3,"s3://crabby-images/8bd2a/8bd2a059cf632e58b226e32fe8451caa97ece469" alt="Switch components sharing a single array variable."
Toggling any one of the switches will update the array:
data:image/s3,"s3://crabby-images/9775d/9775d38513126ef94f1e2fee08a85475c33bf034" alt="Toggling one of the switch components will update the array."
Disabled switch
We can use the disabled
prop to disable a switch:
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch label="off disabled" :value="false" disabled></v-switch>
</div>
<div class="d-flex justify-center mt-2">
<v-switch label="on disabled" :value="true" disabled></v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
};
</script>
data:image/s3,"s3://crabby-images/2821f/2821fee3227dffe10edc0785bb17efd32f911f3f" alt="Disabled switch components."
Switch in loading state
Use the loading
prop to set a switch to the loading state:
<template>
<v-app>
<div class="d-flex justify-center mt-2">
<v-switch label="off loading" :value="false" loading="primary"></v-switch>
</div>
<div class="d-flex justify-center mt-2">
<v-switch label="on loading" :value="true" loading="primary"></v-switch>
</div>
</v-app>
</template>
<script>
export default {
name: 'App',
};
</script>
data:image/s3,"s3://crabby-images/4ca83/4ca8331e934888a5a94434e2e25f479054d7d13b" alt="Switch components in the loading state."
Key takeaways
Switches are useful for taking boolean input from users.
Use the v-switch
component and its various props to create and customize them.
Every Crazy Thing JavaScript Does
A captivating guide to the subtle caveats and lesser-known parts of JavaScript.
data:image/s3,"s3://crabby-images/ea530/ea530111f6f82839f5fb82e185233134334567be" alt="Every Crazy Thing JavaScript Does"