Vue Js Input Mask for Time:Vue.js Input Mask for time is a feature that allows developers to enforce a specific format for time input in Vue.js applications. It ensures that users enter time values in a predetermined format, such as “HH:mm” (hours and minutes). This input mask provides a visual guide to users by automatically inserting separators like colons and validating the input against the specified format. It improves user experience, reduces input errors, and ensures consistency in time input across different browsers and devices. Developers can utilize Vue.js libraries or create custom directives to implement this input mask functionality efficiently.
How can I implement an input mask for time in Vue.js?
This code snippet demonstrates a Vue.js input mask for time. The HTML markup contains an input element with a placeholder and a paragraph element for displaying an error message. The input element is bound to the time
data property using v-model
, and the @input
and @blur
event listeners are used to invoke the respective methods, formatTime
and validateTime
.
The formatTime
method is responsible for formatting the input value by removing non-digit characters and splitting it into hours and minutes. If the input matches the desired format, it updates the time
property accordingly.
The validateTime
method checks whether the time is in the valid format (hh:mm) and within the appropriate range (0-23 hours and 0-59 minutes). The isValidTime
property is updated accordingly.
Overall, this code provides an input mask and validation for time input in the format hh:mm, ensuring that the user enters a valid time value.
Vue Js Input Mask for Time Example
<div id="app">
<input type='text' v-model="time" @input="formatTime" @blur="validateTime" placeholder="hh:mm" />
<p v-if="!isValidTime" style="color: red;">Invalid time format</p>
</div>
<script type="module">
const app = Vue.createApp({
data() {
return {
time: '',
isValidTime: true,
};
},
methods: {
formatTime(event) {
let input = event.target.value;
input = input.replace(/\D/g, ''); // Remove non-digit characters
const match = input.match(/^(\d{0,2})(\d{0,2})$/); // Split input into hours and minutes
if (match) {
const hours = match[1] || '00';
const minutes = match[2] || '00';
this.time = `${hours}:${minutes}`;
} else {
this.time = '';
}
},
validateTime() {
const [hours, minutes] = this.time.split(':');
const isValidFormat = /^\d{2}:\d{2}$/.test(this.time);
const isValidTime = isValidFormat && hours >= 0 && hours <= 23 && minutes >= 0 && minutes <= 59;
this.isValidTime = isValidTime;
},
},
});
app.mount('#app');
</script>