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

02-27 阅读 0评论

1、useVModel()的作用

用于父子组件共享数据,

useVModel()的使用------通俗易懂,useVModel()的使用------通俗易懂,词库加载错误:未能找到文件“C:\Users\Administrator\Desktop\火车头9.8破解版\Configuration\Dict_Stopwords.txt”。,使用,修改,名称,第1张
(图片来源网络,侵删)

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

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

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

2、如何使用 

父组件app.vue

    
        
    


import uniInput from './components-input/uni-input.vue'
import {ref} from 'vue'
const flag=ref(true)
const tofather=(data)=>{
    console.log('data',data)
}

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

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

useVModel()的使用------通俗易懂,useVModel()的使用------通俗易懂,词库加载错误:未能找到文件“C:\Users\Administrator\Desktop\火车头9.8破解版\Configuration\Dict_Stopwords.txt”。,使用,修改,名称,第2张
(图片来源网络,侵删)

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

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

子组件uniInput.vue

    
      

{{ flag }}

点击事件 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 }

 1、引入useVModel

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

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

useVModel()的使用------通俗易懂,useVModel()的使用------通俗易懂,词库加载错误:未能找到文件“C:\Users\Administrator\Desktop\火车头9.8破解版\Configuration\Dict_Stopwords.txt”。,使用,修改,名称,第3张
(图片来源网络,侵删)

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

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

3、一般情况 

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

 

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

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

 同理使用useVModel()如下

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

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

 

总结

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


免责声明
本网站所收集的部分公开资料来源于AI生成和互联网,转载的目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。
文章版权声明:除非注明,否则均为主机测评原创文章,转载或复制请以超链接形式并注明出处。

发表评论

快捷回复: 表情:
评论列表 (暂无评论,人围观)

还没有评论,来说两句吧...

目录[+]