data:image/s3,"s3://crabby-images/4b3e5/4b3e591192f8d96e1d682468ad93260133cea4e0" alt=""
preface
In the previous section, we learned how to set styles for custom components. At that time, we set the styles of custom labels in the main DOM:
<style> my-card { display: block; margin: 20px; width: 200px; height: 200px; border: 3px solid #000; } </style> <my-card></my-card>
Although the purpose of style setting is realized, there is a disadvantage: the style of custom label is written dead and not flexible enough.
If you can control the style of user-defined labels inside the user-defined component, it will be relatively flexible, and it can also realize the component principle of "encapsulation and isolation". Today, let's learn how to control the style of user-defined labels inside the user-defined component.
Before starting the text, let's review the overall structure of Shadow DOM:
data:image/s3,"s3://crabby-images/536f0/536f0a36c171380120fd90a7ea15830ec51469b5" alt=""
CSS selector for Shadow DOM
Today's focus is on recognizing several selectors related to Shadow DOM.
: host pseudo class selector
Select the Shadow host element that uses this part of CSS internally, which is actually a custom label element. The usage is as follows:
:host { display: block; margin: 20px; width: 200px; height: 200px; border: 3px solid #000; }
Note: the host selector works only when used in the Shadow DOM.
For example:
data:image/s3,"s3://crabby-images/d4fb4/d4fb489b3619dfdb6d1d165fd274cc3a58126894" alt=""
In addition, you can use the form of: host sub selector to set the style for the sub elements of Shadow Host, such as:
data:image/s3,"s3://crabby-images/c52ff/c52ff11f4e0c8ccb4e54d316e6a60b836cc9999d" alt=""
: the compatibility of the host pseudo class selector is as follows:
data:image/s3,"s3://crabby-images/02171/021715d61233c5c3120b20e628a77699ad4778b1" alt=""
: host() pseudo class function
: host() is used to get the Shadow Host of a given selector. For example, the following code:
<my-card class="my-card"></my-card> <my-card></my-card> <script> class MyCard extends HTMLElement { constructor () { super(); this.shadow = this.attachShadow({mode: "open"}); let styleEle = document.createElement("style"); styleEle.textContent = ` :host(.my-card){ display: block; margin: 20px; width: 200px; height: 200px; border: 3px solid #000; } :host .card-header{ border: 2px solid red; padding:10px; background-color: yellow; font-size: 16px; font-weight: bold; } `; this.shadow.appendChild(styleEle); let headerEle = document.createElement("div"); headerEle.className = "card-header"; headerEle.innerText = "My Card"; this.shadow.appendChild(headerEle); } } window.customElements.define("my-card", MyCard); </script>
: host (. My card) will only select the custom element with the class name of my card, and it can also be followed by a sub selector to select the sub elements under its own node.
It should be noted that the parameter of:: host() must be passed, otherwise the selector function will fail, such as:
data:image/s3,"s3://crabby-images/c5bc6/c5bc6d6fd6055cdaf16474992590bcbe8ee7a75a" alt=""
: host() pseudo class functions are compatible as follows:
data:image/s3,"s3://crabby-images/9402a/9402a91975b79fa680c884f6c019e28fc0097515" alt=""
: host context() pseudo class function
Used to select custom elements within a specific ancestor. The ancestor element selector is passed in through parameters. For example, the following code:
<div id="container"> <my-card></my-card> </div> <my-card></my-card> <script> class MyCard extends HTMLElement { constructor () { super(); this.shadow = this.attachShadow({mode: "open"}); let styleEle = document.createElement("style"); styleEle.textContent = ` :host-context(#container){ display: block; margin: 20px; width: 200px; height: 200px; border: 3px solid #000; } :host .card-header{ border: 2px solid red; padding:10px; background-color: yellow; font-size: 16px; font-weight: bold; } `; this.shadow.appendChild(styleEle); let headerEle = document.createElement("div"); headerEle.className = "card-header"; headerEle.innerText = "My Card"; this.shadow.appendChild(headerEle); } } window.customElements.define("my-card", MyCard); </script>
: host context (#container) will only take effect for user-defined elements whose id is container. The effect is as follows:
data:image/s3,"s3://crabby-images/488e1/488e132ad18ffec3a77b2f58b65aa5e041203859" alt=""
Note: the parameters here are also required, otherwise the whole selector function will not take effect.
Its compatibility is as follows:
data:image/s3,"s3://crabby-images/36e2e/36e2e45465fe808c4997098f35e6a623aa3fd899" alt=""
The necessity of coexistence of: host and: host()
After reading the above introduction, many people may have a doubt: host (. My card) {} can't be used directly: host My card {} instead?
The answer is no!!!, Because:: host My card essentially means to find My card (Shadow root): host (Shadow Host). The structure of Shadow DOM is contradictory.
summary
The above is about the CSS selector of Shadow Host. To summarize:
- : host has the largest range and matches all user-defined element instances;
- : host() selects only custom elements that contain a specific selector;
- : host context() selects a custom element that has a specific selector parent element.
~End of this article, thank you for reading!