首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >必须将样式元素附加到所有ShadowDOM中吗?

必须将样式元素附加到所有ShadowDOM中吗?
EN

Stack Overflow用户
提问于 2018-04-18 16:25:24
回答 2查看 83关注 0票数 1

外部ShadowDOM与内部ShadowDOM之间的CSS空间分离。

代码语言:javascript
复制
<style>
    .foo a.bar { text-decoration: none; color: skyblue; }
</style>
<div class="foo">
    <a id="a1" class="bar">baz</a>
    <custom-element>
        (shadow)
            <a id="a2" class="bar">baz</a>
        (/shadow)
    </custom-element>
    <custom-element>
        (shadow)
            <a id="a3" class="bar">baz</a>
        (/shadow)
    </custom-element>
</div>

在上面的代码中,#a1是应用样式,而#a2#a3则不是。因此,我总是为每个ShadowDOM追加样式元素。风格元素的内容是相同的。

我认为当有很多元素的时候,这对性能是不好的。如果可能的话,我希望通过一个元素来设置CustomElement的默认样式。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-04-18 21:29:40

外部ShadowDOM与内部ShadowDOM之间的CSS空间分离。

是的!这是一个主要和有趣的特点阴影DOM。

因此,我总是为每个ShadowDOM追加样式元素。风格元素的内容是相同的。我认为当有很多元素的时候,这对性能是不好的。

您可能只正确地从1000的自定义元素(并取决于CPU容量)。

如果您需要应用数千次相同的样式,也许您应该考虑使用没有Shadow DOM的自定义元素。

关于同样的主题,看看这个other SO question

票数 2
EN

Stack Overflow用户

发布于 2019-06-20 09:06:46

尝试以下代码:

代码语言:javascript
复制
<style>
    .foo a.bar { text-decoration: none; color: skyblue; }
</style>
<div class="foo">
    <a id="a1" class="bar">baz</a>
    <custom-element>
        (shadow)
 <link rel='stylesheet' href='youCsspath.css' >
            <a id="a2" class="bar">baz</a>
        (/shadow)
    </custom-element>
    <custom-element>
        (shadow)
           <link rel='stylesheet' href='youCsspath.css' >
            <a id="a3" class="bar">baz</a>
        (/shadow)
    </custom-element>
</div>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49904618

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档