Vue is one of the most popular front-end frameworks at present. It has a typical MVC (Model-View-Controller) architecture to facilitate the integration of data and views. In Vue 3, the v-model function plays an important role as the core of two-way data binding. This article will discuss common applications of this function in Vue applications.
<div id="app"> <input type="text" v-model="message"> <p>{{message}}</p> </div>
var app = new Vue({ el: '#app', data: { message: '' } })
This model provides a single-line text box and a paragraph component. When the text box is entered, the paragraph component instantly displays the entered value. This implementation is convenient and intuitive, and does not need to be used similar to the template syntax in Vue1 and Vue2. It can be seen that the v-model function is simpler and easier to use in Vue 3.
<div id="app"> <input type="password" v-model.trim="password"> <input type="password" v-model.trim="confirmpassword"> <button @click="submit">Submit</button> </div>
In this example, the v-model function modifier trim removes possible irrelevant character input by the user. You can also use the v-model function modifier to check whether the user's input complies with the rules, such as limiting the number of input characters, limiting the types of input characters, etc.
<custom-input v-model="inputValue"></custom-input>
Vue.component('custom-input', { props: ['modelValue'], template: ` <input :value="modelValue" @input="$emit('update:modelValue', $event.target.value)" > ` })
In this custom component, match the standard of the v-model function Usage, prop passes in the modelValue attribute, and the input box will automatically update the value of modelValue.
The above is the detailed content of v-model function in Vue3: application of two-way data binding. For more information, please follow other related articles on the PHP Chinese website!