Vue Js Input Mask Date with Time: To create a Vue js input mask for a date with time (dd/mm/yyyy : hh:mm) using JavaScript, you can utilize a method that formats the input value as the user types. First, bind the input field to a data property in Vue.js. Then, use the keyup
event to trigger a method that modifies the input value based on the desired mask format. Inside the method, check the length of the input value and insert the necessary slashes, colons, and spaces at the appropriate positions. This way, the input field will display the desired mask format as the user types.
How can I implement an input mask for a date with time in Vue.js using a specific format?
This code snippet demonstrates how to implement an input mask for a date with time in Vue.js. The <input>
element is bound to the dateTime
variable using v-model
, which allows two-way data binding. The @input
event is used to trigger the formatDateTime
method whenever the input value changes.
In the formatDateTime
method, the input value is cleaned by removing all non-digit characters using a regular expression. If the cleaned input has a length of at least 12 characters (indicating a complete date and time), it is formatted into separate components: day, month, year, hour, and minute. These components are then combined to form a formatted date with time string, which is assigned back to the dateTime
variable.
This approach ensures that the input value adheres to the desired date with time format (dd/mm/yyyy hh:mm) as the user types.
Vue Js Input mask date with time Example
<div id="app">
<input type="text" v-model="dateTime" @input="formatDateTime" placeholder="dd/mm/yyyy hh:mm">
</div>
<script type="module">
const app = Vue.createApp({
data() {
return {
dateTime: ''
};
},
methods: {
formatDateTime() {
let cleanedInput = this.dateTime.replace(/\D/g, '');
if (cleanedInput.length >= 12) {
const day = cleanedInput.slice(0, 2);
const month = cleanedInput.slice(2, 4);
const year = cleanedInput.slice(4, 8);
const formattedDate = `${day}/${month}/${year}`;
const hour = cleanedInput.slice(8, 10);
const minute = cleanedInput.slice(10, 12);
const formattedTime = `${hour}:${minute}`;
this.dateTime = formattedDate + ' ' + formattedTime;
}
}
}
});
app.mount('#app');
</script>