vue 透传 Attributes(二)

禁用 Attributes 继承

如果你不想要一个组件自动地继承 attribute,你可以在组件选项中设置 inheritAttrs: false

从 3.3 开始你也可以直接在 <script setup> 中使用 defineOptions

<script setup>
defineOptions({
  inheritAttrs: false
})
// ...setup 逻辑
</script>

最常见的需要禁用 attribute 继承的场景就是 attribute 需要应用在根节点以外的其他元素上。通过设置 inheritAttrs 选项为 false,你可以完全控制透传进来的 attribute 被如何使用。

这些透传进来的 attribute 可以在模板的表达式中直接用 $attrs 访问到。

<span>Fallthrough attribute: {{ $attrs }}</span>

这个 $attrs 对象包含了除组件所声明的 props 和 emits 之外的所有其他 attribute,例如 classstylev-on 监听器等等。

有几点需要注意:

  • 和 props 有所不同,透传 attributes 在 JavaScript 中保留了它们原始的大小写,所以像 foo-bar 这样的一个 attribute 需要通过 $attrs['foo-bar'] 来访问。

  • 像 @click 这样的一个 v-on 事件监听器将在此对象下被暴露为一个函数 $attrs.onClick

现在我们要再次使用一下之前小节中的 <MyButton> 组件例子。有时候我们可能为了样式,需要在 <button> 元素外包装一层 <div>

<div class="btn-wrapper">
  <button class="btn">click me</button>
</div>

多根节点的 Attributes 继承

和单根节点组件有所不同,有着多个根节点的组件没有自动 attribute 透传行为。如果 $attrs 没有被显式绑定,将会抛出一个运行时警告。

<CustomLayout id="custom-layout" @click="changeValue" />

如果 <CustomLayout> 有下面这样的多根节点模板,由于 Vue 不知道要将 attribute 透传到哪里,所以会抛出一个警告。

<header>...</header>
<main>...</main>
<footer>...</footer>
如果 $attrs 被显式绑定,则不会有警告:
<header>...</header>
<main v-bind="$attrs">...</main>
<footer>...</footer>

在 JavaScript 中访问透传 Attributes

如果需要,你可以在 <script setup> 中使用 useAttrs() API 来访问一个组件的所有透传 attribute:

<script setup>
import { useAttrs } from 'vue'

const attrs = useAttrs()
</script>

如果没有使用 <script setup>attrs 会作为 setup() 上下文对象的一个属性暴露:

export default {
  setup(props, ctx) {
    // 透传 attribute 被暴露为 ctx.attrs
    console.log(ctx.attrs)
  }
}

相关推荐

  1. vue Attributes()

    2024-03-31 10:06:07       36 阅读
  2. vue Attributes

    2024-03-31 10:06:07       36 阅读
  3. Android 上层的View/不 点击事件 到下层

    2024-03-31 10:06:07       35 阅读
  4. vue3 key Attribute 的变化

    2024-03-31 10:06:07       61 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-31 10:06:07       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-31 10:06:07       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-31 10:06:07       82 阅读
  4. Python语言-面向对象

    2024-03-31 10:06:07       91 阅读

热门阅读

  1. 使用 R 读取Excel文件的特定列

    2024-03-31 10:06:07       36 阅读
  2. SVG XML 格式定义图形入门介绍

    2024-03-31 10:06:07       45 阅读
  3. Kotlin语言教程

    2024-03-31 10:06:07       35 阅读
  4. FastAPI+React全栈开发16 设置一个React工作流

    2024-03-31 10:06:07       41 阅读
  5. Ecology9 分部(单位)获取示例

    2024-03-31 10:06:07       40 阅读
  6. I/O密集型任务和CPU密集型任务的理解与对比

    2024-03-31 10:06:07       36 阅读
  7. 给网站添加安全措施 -- http -> https

    2024-03-31 10:06:07       40 阅读
  8. vue 透传 Attributes

    2024-03-31 10:06:07       36 阅读
  9. 40个学习网站合集

    2024-03-31 10:06:07       34 阅读
  10. MySql的下载与安装

    2024-03-31 10:06:07       41 阅读
  11. Zookeeper设计的思想

    2024-03-31 10:06:07       41 阅读
  12. pg_rman在恢复服务器上恢复源库的备份

    2024-03-31 10:06:07       31 阅读
  13. js的Number对象和全局对象

    2024-03-31 10:06:07       35 阅读