CSS:如何在 Shadow DOM 根中定位 ::slotted 兄弟姐妹?

spb*_*bks 13 css web-component shadow-dom native-web-component

我知道规范目前只允许 ::slotted 的复合选择器,即::slotted(my-first + my-second)不允许,但这样的事情应该工作吗?

::slotted(x-first) + ::slotted(x-second) { /* css */ }
Run Code Online (Sandbox Code Playgroud)

有什么方法可以定位开槽的兄弟姐妹(除了使用全局 css)?如果没有,我会在哪里提交这样的请求?谢谢。

Pil*_*lan 13

当然,你可以选择siblingsslots / slotted

不能做的是选择一个已经开槽的元素,而不是顶级节点

选择兄弟姐妹:

slot[name=<slotname>] ~ <selector>

选择开槽的顶级节点

::slotted(<compound-selector>)

一个复合选择包含标记/班/ ID /名称等,但不得有任何组合程序。喜欢<space>的例子。

.myClass 好的

<anyTag>[<anyAttribute>[=<anyValue>]] 好的

.<myClass> > .<anotherClass>

例子

var element = document.querySelector('.templateMe');
var shadow = element.attachShadow({mode: 'open'});
var template = document.querySelector('.myTemplate');
shadow.appendChild(template.content.cloneNode(true));
Run Code Online (Sandbox Code Playgroud)
<template class="myTemplate">
  <style type="text/css">
    ::slotted([slot=slot1]) { /* slot1 every slotted element - YES */
      color: red;
    }
    
    slot[name=slot1] { /* slot1 itself - YES */
      text-decoration: underline;
    }
    
    slot[name=slot1] + .siblingA { /* slot1 siblingA (direct sibling) - YES */
      color: green;
    }
    
    slot[name=slot1]  ~ .siblingB { /* slot1 siblingB (any sibling) - YES */
      color: orange;
    }
    
    slot[name=slot2]::slotted(.selectMeA) { /* slot2 TOP-LEVEL CHILD (slotted) - YES */
      color: purple;
    }
    
    slot[name=slot2]::slotted(.selectMeB) { /* slot2 NOT TOP-LEVEL CHILD - NO */
      font-weight: bold;
    }
    
    slot[name=slot2]::slotted(.selectMeC[name=myName]) { /* slot2 TOP-LEVEL CHILD (slotted) - YES */
      color: khaki;
    }
    
    slot[name=slot2] + .siblingC { /* slot2 sibling - YES */
      color: blue;
    }
    
  </style>
  <div>
    <slot name="slot1"></slot>
    <div class="siblingA">Sibling A of Slot 1</div>
    <div class="siblingB">Sibling B of Slot 1</div>
  </div>
  <hr/>
  <div>
    <slot name="slot2"></slot>
    <div class="siblingC">Sibling C of Slot 2</div>
  </div>
</template>

<div class='templateMe'>
  <span slot="slot1">Im in Solt 1</span>
  <span slot="slot2" class="selectMeA">
    Im in Solt 2, im selectable.
    <div class='selectMeB'>
      NOT selectable (because no top level node of slotted)!
    </div>
  </span>
  <span slot="slot2" class="selectMeC" name="myName">Im in Solt 2 too and selectable!</span>
</div>
Run Code Online (Sandbox Code Playgroud)

更多在这里

带槽元素(来自轻量级 DOM),::slotted(selector) 允许自己选择带槽元素,但不能选择它们的子元素。

  • 感谢您的详细回答。在你的例子中,我正在寻找的是: `slot[name=slot2]::slotted(.selectMeA + .selectMeC)`,如果我理解正确的话,这是不可能的,尽管两者都是顶级子级。 (2认同)
  • 我试过 `::slotted(.selectMeA) + ::slotted(.selectMeC)` 但这也不是很奇怪。`::slotted` 似乎是该行的结尾。 (2认同)
  • 任何人都知道这是否是出于某种原因而这样做的,或者组合器是否可能在未来起作用但目前还没有?我想要它们 (2认同)

Int*_*lia 5

放置在插槽中的 DOM 应该由拥有该 DOM 的 CSS 控制,而不是由自定义元素控制。

Web 组件允许对放置在您的 Slot 中的 DOM 进行非常小的 CSS 控制。几乎只是顶级元素(以及由子节点自动继承的东西。)

这是一个有意识的决定,可能永远不会改变。