vue3中的useAttrs和props的区别

在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 中消失, 这个特性要注意一下

相关推荐
归于尽8 分钟前
V8 引擎是如何给 JS"打扫房间"的 ?
前端·javascript
小old弟8 分钟前
让对象保持定义的顺序来排列
前端
漫天星梦9 分钟前
前端列表页大数据内存优化的思考
前端·面试
自由逐风9 分钟前
JS 处理长整型数字的坑:从雪花 ID 精度丢失说起
javascript
爱学习的茄子10 分钟前
从0到1:揭秘前端网络请求的进化之路
前端·javascript·面试
云动雨颤13 分钟前
流量分发代码实战|学会用JS控制用户访问路径
javascript
欢乐时光c14 分钟前
常见请求头响应头的含义
前端·面试
wzyoung14 分钟前
element-ui让el-form绑定的深层对象也能通过内置的resetFields方法重置
前端·javascript·vue.js
用户730870117930814 分钟前
使用 CSS background-blend-mode 创造惊艳的视觉效果
前端
高端章鱼哥15 分钟前
Python 项目快速部署到 Linux 服务器基础教程
前端