您现在的位置是:首页 > 技术教程 正文

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

admin 阅读: 2024-03-30
后台-插件-广告管理-内容页头部广告(手机)

1、useVModel()的作用

用于父子组件共享数据,

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

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

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

2、如何使用 

父组件app.vue

  1. <script setup>
  2. import uniInput from './components-input/uni-input.vue'
  3. import {ref} from 'vue'
  4. const flag=ref(true)
  5. const tofather=(data)=>{
  6. console.log('data',data)
  7. }
  8. script>
  9. <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

  1. <script setup lang="ts">
  2. import {defineProps,defineEmits} from 'vue'
  3. import {useVModel} from '@vueuse/core'
  4. const emit=defineEmits([])
  5. const props=defineProps({
  6. flag:{
  7. type:Boolean,
  8. default:false
  9. }
  10. })
  11. const flag=useVModel(props,'flag',emit)
  12. const changeflag=()=>{
  13. flag.value=!flag.value
  14. }
  15. script>
  16. <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都是如下使用,不带名称

"flag">

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

  1. const props=defineProps({
  2. modelValue:{
  3. type:Boolean,
  4. default:false
  5. }
  6. })

 同理使用useVModel()如下

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

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

"flag" @update:model-value="tofather">

总结

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

标签:
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

在线投稿:投稿 站长QQ:1888636

后台-插件-广告管理-内容页尾部广告(手机)
关注我们

扫一扫关注我们,了解最新精彩内容

搜索