2024-07-26 定义一个vue组件,并通过双向绑定进行通信
我写了一个input组件(vue3)
<template> <div> <input class="inp" :value="modelValue" @input="$emit('update:modelValue', $event.target.value)" /> </div> </template> <script> export default { name: "tInput", }; </script> <script setup> const props = defineProps({ modelValue: { type: String, default: "", }, }); const emit = defineEmits(['update:modelValue']); </script> <style> .inp { height: 28px; border-radius: 6px; font-size: 18px; line-height: 28px; padding: 0 4px; } </style>
然后在页面应用:
<template> <div class="t-ui-flex-start t-ui-gap-16"> <t-input v-model="value"></t-input> <button @click="testBtn">测试</button> </div> </template> <script setup> import { ref } from "vue"; const value = ref(''); const testBtn = () => { console.log("value", value.value); } </script>
效果图:
当你在input框输入值时会同时更新input组件的value,然后点击【测试】按钮打印input的value值就是你输入的值
问题1:一个普通的组件如何实现双向绑定?
使用defineEmits暴露出$emit值,并用$emit绑定组件的一些设值方法,如
@input="$emit('update:modelValue', $event.target.value)"
问题2:为什么我写的和你的差不多一样,但是点击按钮想打印出input的值却死活都是空?
原因:应该是你的@input事件写错了,检查有没有空格,我就是在'update: modelValue'中间写了个空格导致无法获取到input的值!
问题3:设计组件双向数据绑定时为什么不能随便给组件绑定一个value值?
原因:给组件设计双向数据绑定的变量名的固定写法为modelValue,不能写成其他名称如value亦或者inpValue等等,这是一种固定写法,当你使用了该名称作为input的value值时,就可以使用双向数据绑定input的value值。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
2022-07-26 2022-07-26 npm install -g n 升级npm失败
2022-07-26 2022-07-26 初始化react-native项目时报错Error: Command failed: yarn add react-native --exact
2022-07-26 2022-07-26 vue+iview table组件 Invalid prop: type check failed for prop "rowKey". Expected Boolean, got String with value "orders_no_m".
2022-07-26 2022-07-26 js replace函数匹配所有项,替换成指定字符