如何在Shadow DOM/Web组件中覆盖CSS

Web组件(Web Components)的主要目的之一是提供封装——能够隐藏HTML标记结构和CSS样式,并与页面上的其他代码分离,这样不同的部分就不会冲突,通过这种方式,这样代码就可以保持漂亮和干净。

影子DOM(Shadow DOM)为我们提供了范围限定的样式封装,并提供了一种让我们随意选择进入(尽可能少)外界的方法。

但是,如果我想使我的组件可自定义某些样式属性,该怎么办?

本文介绍了使用CSS自定义属性穿透Shadow DOM并使你的Web组件可自定义的基础知识。

创建一个HTML元素

我们将使用扩展基本HTML Element的JavaScript类创建自定义HTML元素。然后,我们将使用要创建的标签名称和刚刚创建的类调用 customElements.define()。

 
 
 
 
  1. class AppCard extends HTMLElement {...} 
  2. window.customElements.define('app-card', AppCard); 

在此示例中,我们将创建此简单的Material Design卡片,当我们在HTML上添加此元素时将显示该元素:

首先,我们创建Shadow DOM root,然后将HTML和CSS字符串分配给Shadow DOM root 的 innerHTML,如下所示。

 
 
 
 
  1. class AppCard extends HTMLElement { 
  2.   constructor() { 
  3.     super(); 
  4.     const shadowRoot = this.attachShadow({mode: 'open'}); 
  5.         shadowRoot.innerHTML = ` 
  6.        
  7.        
  8.         
    Card title
     
  9.       
 
  •     `; 
  •   }}window.customElements.define('app-card', AppCard); 
  • 覆盖尝试

    在此示例中,我们要修改卡的背景颜色。如果它是HTML中的简单 div 元素,则可以覆盖 card 类或通过CSS选择器访问 div 元素。但是,以下尝试将无效:

     
     
     
     
    1. // access the div  
    2. app-card > div { 
    3.   background-color: #2196F3; 
    4. // override card class 
    5. app-card > .card { 
    6.   background-color: #2196F3; 

    使用CSS自定义属性

    为了解决这个问题,我们可以使用CSS自定义属性(CSS变量)。可以使用CSS中定义的CSS自定义属性来更改自定义元素中的某些CSS属性。

    按照我们的例子,我们将使用属性 background-color 上的变量 card-bg 来获取谁在使用自定义元素所定义的颜色。

     
     
     
     
    1. class AppCard extends HTMLElement { 
    2.   constructor() { 
    3.     super(); 
    4.     const shadowRoot = this.attachShadow({mode: 'open'}); 
    5.         shadowRoot.innerHTML = ` 
    6.        
    7.        
    8.         
      Card title
       
    9.       
     
  •     `; 
  •   }}window.customElements.define('app-card', AppCard); 
  • 现在,我们将使用 app-card 自定义元素,并在Body元素的CSS中创建 card-bg 变量,我们将十六进制颜色 #2196F3 分配给变量。

     
     
     
     
    1.  
    2.    
    3.      
    4.    
    5.    
    6.      
    7.    
    8.  

    总结

    使用这种策略,我们可以在你的文档中拥有一个封装的CSS元素,同时我们可以允许使用CSS对一些属性进行自定义。你可以在这里访问一个完整的例子。

    分享题目:如何在Shadow DOM/Web组件中覆盖CSS
    路径分享:http://www.csdahua.cn/qtweb/news4/431304.html

    网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网

    成都快上网为您推荐相关内容

    营销型网站建设知识

    分类信息网