跨境派

跨境派

跨境派,专注跨境行业新闻资讯、跨境电商知识分享!

当前位置:首页 > 工具系统 > 其他工具 > useVModel()的使用------通俗易懂

useVModel()的使用------通俗易懂

时间:2024-03-26 21:40:46 来源:网络cs 作者:付梓 栏目:其他工具 阅读:

标签: 使用 

1、useVModel()的作用

用于父子组件共享数据,

1、父组件有个flag(Boolean)属性

2、将flag属性传递给子组件,要实现双向数据绑定

3、flag属性在子组件发生变化,父组件的flag属性一起改变

2、如何使用 

父组件app.vue

<template>    <div>        <uniInput v-model:flag="flag" @update:flag="tofather"></uniInput>    </div></template><script setup>import uniInput from './components-input/uni-input.vue'import {ref} from 'vue'const flag=ref(true)const tofather=(data)=>{    console.log('data',data)}</script><style scoped lang="less"></style>

1、父组件有flag属性,使得flag和子组件uniInput双向绑定

2、使用v-model:flag进行双向绑定,v-model的默认写法是(v-model:modelValue),其中modelValue是传递到子组件的props值

3、@update:flag是子组件中的flag发生改变,执行的回调函数

4、tofather函数的参数 data 是flag改变时,回调函数传递的参数 

子组件uniInput.vue

<template>    <div>      <h1>{{ flag }}</h1>      <button @click="changeflag">点击事件</button>    </div></template><script setup lang="ts">import {defineProps,defineEmits} from 'vue'import {useVModel} from '@vueuse/core'const emit=defineEmits([])const props=defineProps({  flag:{    type:Boolean,    default:false  }})const flag=useVModel(props,'flag',emit)const changeflag=()=>{  flag.value=!flag.value}</script><style scoped lang="less"></style>

 1、引入useVModel

 2、使用props接收父组件传递的值(接收flag)

 3、用useVModel()函数,传参props,双向绑定的flag,emit

 4、当执行changeflag函数时,检测到flag被修改,会默认执行回调函数update:flag,不会在代码中体现

 5、默认执行emit('update:flag',flag),参数是当前双向绑定的值

3、一般情况 

 多数情况下,使用v-model都是如下使用,不带名称

<uniInput v-model="flag"></uniInput>

所以在子组件使用如下方式接收,因为v-model默认名称是modelValue

const props=defineProps({  modelValue:{    type:Boolean,    default:false  }})

 同理使用useVModel()如下

const flag=useVModel(props,'modelValue',emit)

 当flag改变时,默认调用update:modelValue的emit,所以接收回调如下

<uniInput v-model="flag" @update:model-value="tofather"></uniInput>

总结

useVModel()用来实现父子组件间数据的双向绑定,若不想使用默认回调,也可以自己使用emit实现回调 

本文链接:https://www.kjpai.cn/news/2024-03-26/149227.html,文章来源:网络cs,作者:付梓,版权归作者所有,如需转载请注明来源和作者,否则将追究法律责任!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。

文章评论