关于vue3的inheritAttrs属性和$attrs的部分用法
作者:互联网
当我们在父组件中想要为子组件的某一个标签添加一些样式
<show-message id="lkx" class="lkx" title="HHH" content="123"></show-message>
如果不做任何设置,那么子组件被渲染出来是这样的
他会在子组件的根标签上添加样式,这显然不符合我们的需求,所以我们在子组件添加该属性
inheritAttrs:false,
此时浏览器渲染结果为
看不到任何的样式加载了,这时我们可以在想要添加的子组件某一标签的样式处添加:class="$attrs.class"
<template> <div> <h2 >{{title}}</h2> <h2 :class="$attrs.class">{{content}}</h2> <h2>{{info.msg}}</h2> </div> </template>
这样就可以将想要的样式添加到想要的标签上啦,渲染后的结果如下
当然,如果父组件有id和class,可以使用:="$attrs"优化一下写法,v-bind = "$attrs"
<div> <h2 >{{title}}</h2> <h2 :="$attrs">{{content}}</h2> <h2>{{info.msg}}</h2> </div>
结果如下
标签:样式,标签,inheritAttrs,添加,attrs,vue3,组件,class 来源: https://www.cnblogs.com/lkx666/p/15967128.html