Vue3封装知识点(一)组件之间的传值

Vue3封装知识点(一)组件之间的传值

用了很久一段时间Vue3+Ts了,工作中对一些常用的组件也进行了一些封装,这里对封装的一些方法进行一些简单的总结。

1.props传递

首先在主组件进行定义传值

xml 复制代码
<template>
    <div>
        这里是主组件
        <common :first="first"></common>
    </div>
</template>
​
<script setup lang="ts">
import common from './common.vue';
import {ref} from 'vue'
const first=ref('传入通用组件的值')

代码中common是定义的要封装的组件,这里first即是要传入的值

然后子组件要进行接收传来的值,如下

xml 复制代码
<template>
    <div>
    这里是通用组件
    {{ props.first }}
    </div>
</template>
​
<script setup lang="ts">
​
const props=defineProps({
    first:String
})
</script>

这里与vue2不同的是需要利用defineProps进行参数的接收,我这里用到了TS,所以也加入了类型声明。

2.监听参数变化

在一些业务中,父组件传给子组件的数据有时候是动态的,这个时候就需要对参数的改变进行识别了

这里就用到watch了

javascript 复制代码
watch(
  props,
  (newVal) => {
    console.log(props,'props改变了');
  },
  {
    immediate: true,
  }
);

对props进行监听,如果进行改变,然后怎么进行操作,可以更细节的处理了。

这里watch的使用可以参考官网cn.vuejs.org/api/reactiv...

3.触发事件

子向父亲传递信息,或者使用父亲的方法应该怎么做呢,这是就是用到emits了

首先父组件对子组件绑定方法

xml 复制代码
<template>
    <div>
        这里是主组件
        <common :first="first" @getValue="getValue"></common> //这里的@就是绑定的方法
    </div>
</template>
​
<script setup lang="ts">
import common from './common.vue';
import {ref} from 'vue'
const first=ref('传入通用组件的值')
const getValue=(val:string)=>{ //注意这里的参数即是子组件想要传的值
    console.log(val);
}
</script>

绑定后需要在子组件进行接收

xml 复制代码
<template>
    <div>
    这里是通用组件
    {{ props.first }}
    </div>
</template>
​
<script setup lang="ts">
​
const props=defineProps({
    first:String
})
const emits=defineEmits(['getValue'])//这里进行定义接收
watch(
  props,
  (newVal) => {
    console.log(props,'props改变了');
    emits('getValue','我触发了') //想要触发时进行调用
  },
  {
    immediate: true,
  }
);
</script>

这里在子组件定义接收后,再触发时用emits('方法名',传递参数)的形式进行触发,而这个传递参数是你在父组件绑定方法中所定义的参数。

4.调用子组件方法

在封装中,也会遇到一些调用子组件的方法,我现在常用的是下面这种

先用defineExpose将方法进行暴露

kotlin 复制代码
const out=(val:string)=>{
    console.log('我是子组件的方法',val);
}
defineExpose({
    out,
});

然后在父组件使用ref绑定子组件,获取其方法

xml 复制代码
<template>
    <div>
        这里是主组件
        <common :first="first" @getValue="getValue" ref="Common"></common>
    </div>
</template>
​
<script setup lang="ts">
import common from './common.vue';
import {ref,onMounted} from 'vue'
const first=ref('传入通用组件的值')
const getValue=(val:string)=>{
    console.log(val);
}
const Common=ref() //这里ref名称与上面绑定的ref要保持一致
onMounted(() => {
    Common.value.out('传给你')
    // 结果为 '我是子组件的方法 传给你'
});
</script>

这里就是先用ref绑定,然后利用其调用方法,括号内的参数即在子组件定义参数。

5.插槽

插槽方法可以见我以前总结的内容,这里不再详细讲解(原文在csdn)

blog.csdn.net/qq_49907632...

6.总结

上述内容其实就是对常用的组件传值进行的一个总结,真实内容封装其实还是要看组件的具体需求,但是都可能是对这些传值进行的一个应用,后续如果对封装有进一步了解,会进一步补充,敬请期待。。。

其他更新

Vue3封装技巧(二)v-model的应用

Vue3封装知识点(三)依赖注入:project和inject详细介绍

相关推荐
saber_andlibert28 分钟前
TCMalloc底层实现
java·前端·网络
逍遥德29 分钟前
如何学编程之01.理论篇.如何通过阅读代码来提高自己的编程能力?
前端·后端·程序人生·重构·软件构建·代码规范
冻感糕人~43 分钟前
【珍藏必备】ReAct框架实战指南:从零开始构建AI智能体,让大模型学会思考与行动
java·前端·人工智能·react.js·大模型·就业·大模型学习
程序员agions1 小时前
2026年,“配置工程师“终于死绝了
前端·程序人生
alice--小文子1 小时前
cursor-mcp工具使用
java·服务器·前端
晚霞的不甘1 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
小迷糊的学习记录1 小时前
0.1 + 0.2 不等于 0.3
前端·javascript·面试
梦帮科技2 小时前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
VT.馒头2 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
css趣多多3 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js