浅谈vue3组件通信的几种方式

vue3组件间怎么进行通信?下面本篇文章带大家了解一下vue3组件通信的几种方式,希望对大家有所帮助。

浅谈vue3组件通信的几种方式

vue3组件通信方式为以下几种

props$emit$expose / ref$attrsv-modelprovide / injectVuexmitt

【相关推荐:《vue.js教程》】

props

  1. const props = defineProps({ // 写法一 msg2:String // 写法二 msg2:{ type:String, default:'' } }) console.log(props) // {msg2:'这是传级子组件的信息2'}

登录后复制

$emit

  1. //Child.vue    // 写法一    
    按钮
        // 写法二    
    按钮
    // 方法一 const emit = defineEmits(['myClick'],['myClick2']) // 方法二 const handleClick = () => { emit('myClick','这是发送给父组件的信息'); } // 方法二 不适用于vue3.2,使用的useContext()已经舍弃 import { useContext } from 'vue' const { emit } = useContext() const handleClick = () => { emit('myClick','这是发送给父组件的信息' }// Parent.vue响应     import child from "./child.vue" import onMychilk = (msg) => { console.log(msg) // 父组件收到的信息 }

登录后复制

expose / ref

父组件获取子组件的属性或者调用子组件方法

立即学习“前端免费学习笔记(深入)”;

  1. // 方法一:useContext() vue3.2 之后已经舍弃 import { useContext } from 'vue' const ctx = useContext() // 对外暴露属性方法等都可以 ctx.expose({ childName: '这是子组建的属性', someMethod(){ console.log('这是子组件的方法') } })// Parent.vue 注意 ref="comp"         import child from './child.vue' import { ref } from 'vue' const comp = ref(null) const handleClick = () => { console.log(comp.value.childName) comp.value.someMethod() // 调用子组件对外暴露的方法 }

登录后复制

attts

attrs:包含父作用域除class和style除外的非props属性集合

  1. // 父组件 import child from './child.vue' import { ref,reactive } from 'vue const msg1 = ref('111') const msg2 = ref('222')// 子组件 import { defineProps,useContext,useAttars } from 'vue' const props = defineProps({ msg1: String }) // 方法1 const ctx = useContext() console.log(ctx.attars) // {msg2:'222',title:'333'} // 方法2 const attrs = useAttars() console.log(attars) // {msg2:'2222',title:'3333'}

登录后复制

v-model

可以支持多个数据双向绑定

  1. import child from './child.vue' import { ref,reactive } from 'vue' const key = ref('111') const value = ref('222')//子组件    // 方法一 v3.2 已被移除 import { useContext } from 'vue' const { emit } = useContext() // 方法二 import { defineEmits } from 'vue' const emit = defineEmits(['key','value']) //用法 const handleClick = () => { emit('update:key','新的key') emit('update:value','新的value') }

登录后复制

provide / inject

provide/inject为依赖注入provide:可以让我们指定想要提供给后代组件的数据inject:在任何后代组件中接受想要添加在这个组件上的数据,不管组件嵌套多深都可以直接拿来用

  1.     // 父组件     import { provide } from 'vue' const name = provide('name') console.log('name','沐华')     //子组件     import { inject } from 'vue' const name = inject('name') console.log(name) //木华

登录后复制

Vuex

  1.    //store/index.js   import { createStore } from 'vuex'   export default createStore({       state:{count:1},       getters:{           getCount:state=>state.count       },       mutations:{           add(state){               state.count++           }       }      })    // main.js    import { createApp } from 'vue'    import APP from './App.vue'    import store from './store'    createApp(APP).use(store).mount("#app")        // 直接使用            
                {{ $store.state.count }}        
                        // 获取     import { useStore,computed } from 'vuex' const store = useStore() console.log(store.state.count) const count = computed (()=>store.state.count) console.log(count)

登录后复制

mitt

Vue3中已经没有了EventBus跨组件通信,替代方案mitt.js,但原理方式EventBus是一样的
安装方式 npm i mitt -S
封装

  1. mitt.jsimport mitt from 'mitt'const mitt = mitt()export default mitt

登录后复制

组件之间使用

  1. // 组件A  import mitt from './mitt' const handleClick = () => { mitt.emit('handleChange') }// 组件B import mitt from './mitt'import { onUnmounted } from 'vue'const someMethod = () => {...}mitt.on('handleChange',someMethod)onUnmounted(()=>{ mitt.off('handleChange',someMethod)})

登录后复制

更多编程相关知识,请访问:vue.js教程!!

以上就是浅谈vue3组件通信的几种方式的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
编程技术

分享Vue3全新状态管理工具:Pinia

2025-4-1 17:23:33

编程技术

介绍Vue3中Composition API及其核心用法

2025-4-1 17:23:47

0 条回复 A文章作者 M管理员
欢迎您,新朋友,感谢参与互动!
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
私信列表
搜索