Vue3 组件传值(v-model)

//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>

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值