这篇文章主要讲解了“Vue3常用的通讯方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3常用的通讯方式有哪些”吧!
父组件
<template>
<div>
<Child :msg="msg" :obj="obj" />
</div>
</template>
<script setup>
import { ref, reactive } from 'vue'
// Vue3.2版本setup语法糖引入组件不需要注册便可以使用组件
import Child from './child.vue'
const msg = ref('一只豆豆')
// 传递复杂类型数据
const obj = reactive({name: '豆豆'})
</script>
子组件
<template>
<div></div>
</template>
<script setup>
// Vue3.2版本setup语法糖 defineProps 不需要引入可以直接使用
const props = defineProps({
msg: {
type: String,
default: ''
},
obj: {
type: Object,
default: () => {}
}
})
console.log('msg', props.msg); // 一只豆豆
console.log('obj', props.obj.name); // 豆豆
</script>
父组件
<template>
<div>
<Child @myClick="myClick" />
</div>
</template>
<script setup>
import { ref, reactive } from 'vue'
import Child from './child.vue'
const myClick = val => {
console.log('val', val); // emit传递信息
}
</script>
子组件
<template>
<div>
<button @click="handleClick">click me</button>
</div>
</template>
<script setup>
// Vue3.2版本setup语法糖 defineEmits 不需要引入可以直接使用
const emit = defineEmits(['myClick']) // 如果有多个emit事件可以往数组后边添加即可
const handleClick = ()=>{
emit("myClick", "emit传递信息")
}
</script>
在Vue3中就没有EventBus了,可以使用mitt.js来替代
安装
$ npm install --save mitt
bus.js
import mitt from 'mitt'
export default mitt()
兄弟组件A emit触发
<template>
<div>
<button @click="handleClick">click me</button>
</div>
</template>
<script setup>
import bus from './bus'
const handleClick = () => {
bus.emit('foo', '豆豆')
}
</script>
兄弟组件B on接收
<template>
<div></div>
</template>
<script setup>
import bus from './bus'
bus.on('foo', e => {
console.log('e', e) // '豆豆'
})
</script>
Vue2版本是可以通过修饰符.sync让子组件修改父组件的值,但是Vue3就取消这个修饰符,融合到v-model里边去了
父组件
<template>
<div>
<div>{{ name }}</div>
<div>{{ age }}</div>
<Child v-model:name="name" v-model:age="age" />
</div>
</template>
<script setup>
import Child from './child.vue'
import { ref } from 'vue'
const name = ref('豆豆')
const age = ref(20)
</script>
子组件
<template>
<div>
<div></div>
<button @click="handleChange">click me</button>
</div>
</template>
<script setup>
// 'update:name' 这样写在console里面就不会有告警了
const emit = defineEmits(['update:name', 'update:age'])
const handleChange = () => {
emit('update:name', '一只豆豆')
emit('update:age', 18)
}
</script>
子组件通过 expose 暴露属性和方法出去
父组件通过 ref 来获取子组件的值和调用方法
父组件
<template>
<div>
<Child ref="myRef" />
<button @click="handleClick">click me</button>
</div>
</template>
<script setup>
import Child from './child.vue'
import { ref } from 'vue'
const myRef = ref(null)
const handleClick = () => {
console.log('myRef', myRef.value.name) // 豆豆
myRef.value.fn() // 一只豆豆
}
</script>
子组件
<template>
<div>
<div></div>
</div>
</template>
<script setup>
// Vue3.2版本setup语法糖 defineExpose 不需要引入可以直接使用
defineExpose({
name: '豆豆',
fn () {
console.log('一只豆豆')
}
})
</script>
provide / inject 可以给后代组件传参,嵌套多少层都没问题
父组件
<template>
<div>
<Child />
</div>
</template>
<script setup>
import Child from './child.vue'
import { ref, provide } from 'vue'
const name = ref('豆豆')
provide('name', name)
</script>
后代组件
<template>
<div>
<div>后代组件name {{ name }}</div>
</div>
</template>
<script setup>
import { inject } from 'vue'
const name = inject('name')
console.log('name', name.value) // 豆豆
</script>
Vue2使用 provide / inject 传递数据不是响应式的,所以只能通过传递一个对象数据才能变成响应式
Vue3使用 provide / inject传递数据就是响应式了,这就很便捷
父组件
<template>
<div>
<Child>豆豆</Child>
</div>
</template>
<script setup>
import Child from './child.vue'
</script>
子组件
<template>
<div>
<slot></slot>
</div>
</template>
<script setup></script>
<template>
<div>
<Child>
豆豆
<template #name>
<div>
<button>一只豆豆</button>
</div>
</template>
</Child>
</div>
</template>
<script setup>
import Child from './child.vue'
</script>
子组件
<template>
<div>
// 普通插槽
<slot></slot>
// 具名插槽
<slot name="name"></slot>
</div>
</template>
<script setup></script>
效果图
父组件
<template>
<!-- v-slot="{scope}" 子组件返回的每一项数据 -->
<Child v-slot="{ scope }" :arr="arr">
<div class="box">
<div>名字:{{ scope.name }}</div>
<div>年龄:{{ scope.age }}</div>
<div>爱好:{{ scope.like }}</div>
</div>
</Child>
</template>
<script setup>
import { reactive } from 'vue'
import Child from './child.vue'
const arr = reactive([
{ name: '张三', age: 18, like: '篮球' },
{ name: '李四', age: 19, like: '排球' },
{ name: '王五', age: 20, like: '足球' }
])
</script>
<style lang="less">
.box {
display: inline-block;
width: 200px;
border: dashed blue 1px;
margin-right: 15px;
padding: 10px;
}
</style>
子组件
<template>
<div>
<!-- :scope="item" 返回每一项 -->
<slot v-for="item in arr" :scope="item" />
</div>
</template>
<script setup>
const props = defineProps({
arr: {
type: Array,
default: () => []
}
})
</script>
效果图
感谢各位的阅读,以上就是“Vue3常用的通讯方式有哪些”的内容了,经过本文的学习后,相信大家对Vue3常用的通讯方式有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。