阴影部分(Shadow Parts)
CSS Shadow Parts 允许开发者在影子树内部的元素上设置 CSS 属性样式。这对于自定义 Ionic Framework 的 Shadow DOM 组件非常有用。
为什么需要 Shadow Parts?
Ionic Framework 是一组分布式的 Web Components。Web Components 遵循 Shadow DOM 规范来实现样式和 标记的封装。
备注
Shadow DOM 有助于防止样式从组件中泄漏,并意外应用到其他元素上。例如,我们为 ion-button 组件分配了一个 .button 类。如果没有 Shadow DOM 封装,如果用户在自己的元素上设置了 .button 类,它会继承 Ionic Framework 的按钮样式。由于 ion-button 是一个 Shadow 组件,这不会成为问题。
然而,由于这种封装,样式也无法渗透到 Shadow 组件的内部元素中。这意味着如果 Shadow 组件在其影子树内渲染元素,则无法直接用 CSS 定位这些内部元素。以 ion-select 组件为例,它会渲染以下标记:
<ion-select>
#shadow-root
<div class="select-text select-placeholder"></div>
<div class="select-icon"></div>
</ion-select>
占位符文本和图标元素位于 #shadow-root 内部,这意味着以下 CSS 无法用于设置占位符样式:
/* 不生效 */
ion-select .select-placeholder {
color: blue;
}
那么我们如何解决这个问题呢?答案是 CSS Shadow Parts!
Shadow Parts 详解
Shadow parts 允许开发者从影子树外部为影子树内部的元素设置样式。为此,必须暴露 part 属性,然后可以使用 ::part 来设置样式。
暴露 Part
在创建 Shadow DOM 组件时,可以通过在影子树内部的元素上分配 part 属性来添加 part。这在 Ionic Framework 的组件中已经实现,最终用户无需进行任何操作。
继续以 ion-select 组件为例,更新后的标记如下所示:
<ion-select>
#shadow-root
<div part="placeholder" class="select-text select-placeholder"></div>
<div part="icon" class="select-icon"></div>
</ion-select>