Web 组件嵌套插槽
Web components nested slots
是否有更好的方式将插槽传递给深层嵌套的组件?
index.html
<outer-comp>
<span slot=foo>Lorem ipsum</span>
</outer-comp>
外部组件:
<inner-comp>
<slot name=foo slot=foo></slot>
</inner-comp>
内部组件:
<slot name=foo></slot>
效果很好:)
class ElOuter extends HTMLElement {
constructor() {
super();
this.attachShadow({ mode: 'open' });
}
connectedCallback() {
this.shadowRoot.innerHTML = `
<p>- outer start</p>
<el-inner>
<slot name="heading" slot="header"></slot>
</el-inner>
<slot></slot>
<p>- outer stop</p>
`;
}
}
customElements.define('el-outer', ElOuter);
class ElInner extends ElOuter {
connectedCallback() {
this.shadowRoot.innerHTML = `
<p>-- inner start</p>
<slot name="header"></slot>
<p>-- inner stop</p>
`;
}
}
customElements.define('el-inner', ElInner);
<el-outer>
<h2 slot="heading">hey</h2>
<p>I will be in the default content</p>
</el-outer>
是否有更好的方式将插槽传递给深层嵌套的组件?
index.html
<outer-comp>
<span slot=foo>Lorem ipsum</span>
</outer-comp>
外部组件:
<inner-comp>
<slot name=foo slot=foo></slot>
</inner-comp>
内部组件:
<slot name=foo></slot>
效果很好:)
class ElOuter extends HTMLElement {
constructor() {
super();
this.attachShadow({ mode: 'open' });
}
connectedCallback() {
this.shadowRoot.innerHTML = `
<p>- outer start</p>
<el-inner>
<slot name="heading" slot="header"></slot>
</el-inner>
<slot></slot>
<p>- outer stop</p>
`;
}
}
customElements.define('el-outer', ElOuter);
class ElInner extends ElOuter {
connectedCallback() {
this.shadowRoot.innerHTML = `
<p>-- inner start</p>
<slot name="header"></slot>
<p>-- inner stop</p>
`;
}
}
customElements.define('el-inner', ElInner);
<el-outer>
<h2 slot="heading">hey</h2>
<p>I will be in the default content</p>
</el-outer>