Правило @font-face
CSS для шрифта, который вы хотите использовать, должно быть объявлено в основном документе, а не в Shadow DOM.
Поскольку в вашем случае оно определено в * Файл 1004 * materialdesignicons.min. css необходимо загрузить в основной документ через глобальный <link>
.
. Обратите внимание, что файл CSS не будет загружен. дважды благодаря кешу браузера.
Кроме того, вы можете добавить его в облегченном DOM веб-компонента или просто объявить правило @font-face
(скопировано из materialdesignicons. css file).
Вот пример работы:
customElements.define( "x-webcomponent", class extends HTMLElement {
constructor() {
super()
this.attachShadow({ mode: "open" })
this.shadowRoot.innerHTML = `
<link rel=stylesheet href=https://cdn.materialdesignicons.com/4.9.95/css/materialdesignicons.min.css>
<span class="mdi mdi-home"></span>`
}
connectedCallback () {
this.innerHTML = `<style>
@font-face {
font-family: "Material Design Icons";
src: url("https://cdn.materialdesignicons.com/4.9.95/fonts/materialdesignicons-webfont.woff?v=4.9.95") format("woff");
}
</style>`
}
} )
<x-webcomponent></x-webcomponent>