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

相关推荐
阿正的梦工坊17 小时前
React:构建用户界面的JavaScript库
javascript·react.js·ui
行走的陀螺仪17 小时前
[特殊字符] JavaScript 设计模式完全指南:从入门到精通(含20种模式)
开发语言·javascript·设计模式
zhangxingchao17 小时前
AI应用开发五:RAG高级技术与调优
前端·人工智能·后端
KaMeidebaby17 小时前
卡梅德生物技术快报|单 B 细胞抗体技术:全犬源单抗制备流程、关键参数与性能验证
前端·数据库·其他·百度·新浪微博
hazel18 小时前
网络与工程化
前端
KnowWhere18 小时前
Vue3 调试技巧:一键挂载组件实例到 Window(仅开发环境生效)
vue.js
胡萝卜术18 小时前
《JavaScript 语言精粹》第三章精读:对象——最基础也最容易被误解的基石
javascript
甜味弥漫18 小时前
一篇文章搞懂CSS中的定位布局
前端
A南方故人18 小时前
vue3常用指令以及注册
前端·javascript·vue.js
helloweilei18 小时前
Vue 3 中 <script setup>顶层 await与 <Suspense>的结合使用
vue.js