欢迎加入QQ群一起探讨交流:581902292

Extraneous non-props attributes (title) were passed to component but could not be automatically inherited because component renders fragment or text root nodes.

大概意思就是给子组件传递的属性,由于子组件呈现片段或文本根节点,无法自动继承;就是"透传 Attributes"。

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

解决方式:手动显示绑定$attrs

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
(1)模板
    <template>
        <h1>多根节点的 Attributes 继承</h1>
        <div :="$attrs"></div>
    </template>
 
(2)渲染函数
    export default defineComponent({
        setup(props,context){
            const attrs = context.attrs
            return ()=>[h('h1','多根节点的 Attributes 继承'), h('div',{...attrs},'透传 Attributes')]
        }
    })
 
(3)JSX / TSX
    export default defineComponent({
        setup(props,context){
            // `attrs` 包含了所有非 props 的 attribute
            const attrs = context.attrs
            return () => {
                return (
                  <>
                    <h1>多根节点的 Attributes 继承</h1>
                    <div {...attrs}>透传 Attributes</div>
                  </>
                )
            }
        }
    })

  

  

  

posted @   £AP︶ㄣOL◢◤LO  阅读(1203)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示