Vue2/3组件上使用v-model双向绑定

首先要明确它就是个语法糖 (v-model 相当于 onChange 的语法糖)
<input type="text" :value= 'name' @input='name = $event.target.value'>

 <p>{{name}}</p>

上面这个功能和v-model是一致的
你自己也可以用@input监控输入的结果 就可以找到target下面的value
下面有一个场景
要实现一个搜索模糊匹配功能,考虑到组件的复用,就单独把搜索框抽出来作为一个子组件。在以往的开发中,
一般会在input框中的值变化时向父组件emit一个事件,并带上一些父组件中需要的参数(比如搜索的关键词,或者搜索之后返回的结果)

大概的实现方式如下:

复制代码
 父组件
<template>
    <div>
        <search v-model="keywords"></search>
        <button @click="submit">提交</button>
    </div>
</template>
<script>
import search from '@/components/index/search.vue'
export default {
    data() {
        return {
            keywords: ''
        }
    },
    components: {
        search
    },
    methods: {
        submit() {
            console.log('keywords:', this.keywords)
        }
    }
}
</script>

子组件
<template>
    <div>
        <input :value="value" @input="$emit('input', $event.target.value)" type="text" name="keywords">
    </div>
</template>
<script>
export default {
    props: ['value']
}
</script>
复制代码

上面是vue2的写法下面说下vue3的写法(这个更简单)

复制代码
子组件
let emit = defineEmits(['update:modelValue'])

function test(value){
   emit('update:modelValue',value)
}


父组件
<location  v-model="locationVal" />

let  locationVal = ref(null)

然后在对应事件打印locationVal  就可以了
复制代码

 

posted @   xuanPhoto  阅读(150)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
点击右上角即可分享
微信分享提示