Vue3 组件传值(v-model)

本文探讨了Vue中自定义组件使用v-model时遇到的命名限制,指出组件prop和事件名不能包含大写字母和短横线,并提供了一个示例代码展示正确用法。当尝试使用`childValue`替代`modelValue`时,发现不符合Vue的命名规则,引发问题。博客邀请读者分享解决方案和经验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//html:
<div id="app">
    <custom-input v-model="modelValue"></custom-input>
    <p>{{modelValue}}</p>
</div>
//script:
<script type="text/javascript">
	let App = Vue.createApp({
	    data(){
	        return{
	            modelValue:""
	        }
	    },
	})
	App.component('custom-input', {
	    props: ['modelValue'],
	    template: `
	        <input :value="modelValue" 
	        @input="$emit('update:modelValue', $event.target.value)"
	        >
	    `
	})
	App.mount("#app")
</script>

Tips:

上面是默认情况,组件上的v-model是使用modelValue作为prop,update:modelValue作为事件。我在修改名称时发现命名时出现的问题:名称只能英文字母小写加数字(例如:childvalue),不能大写(例如:childValue),不能使用“-”分隔(例如:child-value)。

//html
<div id="app">
    <custom-input v-model:childvalue="modelValue"></custom-input>
    <p>{{modelValue}}</p>
</div>
//script
<script type="text/javascript">
    let App = Vue.createApp({
        data(){
            return{
                modelValue:""
            }
        },
    })
    App.component('custom-input', {
        props: ['childvalue'],
        template: `
            <input :value="childvalue" 
            @input="$emit('update:childvalue', $event.target.value)"
            >
        `
    })
    App.mount("#app")
</script>

不清楚是不是自己遗漏了哪方面导致的,欢迎评论区指教

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值