在vue3中, 提供了一个 useAttrs 的方法
它接收到的参数一 prop中可以接收到的数据是基本一样的
如果我们想自已写一个组件, 把 elementPlus 中的期中一个组件封装一下。
可以这样做
1.新建一个 自定义组件 myBtnCom
js
<template>
<div class="mybuttonwrapper">
<el-button :="$attrs">Success</el-button>
</div>
</template>
<script setup>
</script>
从上面的代码中, 我们可以在代码中直接使用 $attrs 来接收所有的属性
也可以使用 useAttrs 函数
import { useAttrs } from "vue";
let $attrs = useAttrs();
父组件中
js
<template>
<div class="home-wrapper">Home</div>
<el-button type="success" color="hotpink" round @click="changeSuccess">{{suctext}}</el-button>
<myBtnCom type="success" color="hotpink" round></myBtnCom>
</template>
在myBtnCom 设置的属性和 elementPlus中的button的属性是一样的, 传到组件内部 ,就可以封装一个和 elementPlus 用法一样的组件了
注意: 我们可以使用 useAttrs 接收到组件中传递的属性, 同样我们也可以使用 defineProps来接收, 但是如果我们使用 defineProps 接收过的属性, 会要useAttrs 中消失, 这个特性要注意一下