如何自定义组件的v-model
如果说要MyInput.vue组件,和父组件App.vue中的name联动
1、MyInput.vue
<template> <div> <input type="textarea" :value='value' @input='(e)=>$emit("input",e.target.value)'> </div> </template> <script> export default { props: ['value'] } </script>
2、App.vue
<MyInput :value="name" @input='name=$event' />
此处,可以使用v-model='name'替换 :value='name' @input='name=$event',即:
<MyInput v-model="name" />
那如果要定义一个MyCheckbox组件呢?
1、MyCheckbox.vue
<template> <div> <input type="checkbox" :checked='checked' @change='(e)=>$emit("change",e.target.checked)'>选项 </div> </template> <script> export default { props: ['checked'] } </script>
2、App.vue
<MyCheckbox :checked='checked' @change="checked=$event" />
如果此处要想使用v-model去替换:checked='checked' @change="checked=$event",即:
<MyCheckbox v-model="checked" />
那么此时是无效的,因为v-model的默认属性是value,默认的事件是input,需要在子组件内去自定义v-model的属性名和事件名
3、MyCheckbox.vue
model: {
prop: 'checked',
event: 'change'
}
此时,<MyCheckbox v-model="checked" />上的v-mode绑定的属性为checked,事件为change
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· 地球OL攻略 —— 某应届生求职总结