当前位置:   article > 正文

vue 透传 Attributes(二)

vue 透传 Attributes(二)

禁用 Attributes 继承

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

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

  1. <script setup>
  2. defineOptions({
  3. inheritAttrs: false
  4. })
  5. // ...setup 逻辑
  6. </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>

  1. <div class="btn-wrapper">
  2. <button class="btn">click me</button>
  3. </div>

多根节点的 Attributes 继承

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

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

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

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

在 JavaScript 中访问透传 Attributes

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

  1. <script setup>
  2. import { useAttrs } from 'vue'
  3. const attrs = useAttrs()
  4. </script>

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

  1. export default {
  2. setup(props, ctx) {
  3. // 透传 attribute 被暴露为 ctx.attrs
  4. console.log(ctx.attrs)
  5. }
  6. }

本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号