Vue_07(组件的v-model)
2021/12/20 6:19:39
本文主要是介绍Vue_07(组件的v-model),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
v-model | Vue.js https://v3.cn.vuejs.org/guide/component-custom-events.html#v-model-%E5%8F%82%E6%95%B0
在input中可以使用v-model来完成双向绑定
<input v-model="message"> #上下等同 <input :value="message" @input="message = $event.target.value">
vue也支持在组件上使用v-model
<hy-input v-model="message"></hy-input> #上下等同 <hy-input :modelValue="message" @update:model-value="message = $event"></hy-input>
组件v-model的实现
<template> <div> <input :value="modelValue" @input="btnClick"> </div> </template> <script> export default { props: ['modelValue'], emits: ["update:modelValue"], methods: { btnClick(event) { this.$emit("update:modelValue", event.target.value); } } } </script> <style scoped> </style>
利用computed实现(更佳)
<template> <div> <input v-model="value"> <input v-model="why"> </div> </template> <script> export default { props: { modelValue: String, title: String }, emits: ["update:modelValue", "update:title"], computed: { value: { set(value) { this.$emit("update:modelValue", value); }, get() { return this.modelValue; } }, why: { set(why) { this.$emit("update:title", why); }, get() { return this.title; } } } } </script> <style scoped> </style>
这篇关于Vue_07(组件的v-model)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-16Vue3资料:新手入门必读教程
- 2024-11-16Vue3资料:新手入门全面指南
- 2024-11-16Vue资料:新手入门完全指南
- 2024-11-16Vue项目实战:新手入门指南
- 2024-11-16React Hooks之useEffect案例详解
- 2024-11-16useRef案例详解:React中的useRef使用教程
- 2024-11-16React Hooks之useState案例详解
- 2024-11-16Vue入门指南:从零开始搭建第一个Vue项目
- 2024-11-16Vue3学习:新手入门教程与实践指南
- 2024-11-16Vue3学习:从入门到初级实战教程