我想提供一种可能性,使用装饰器以不同的外观和思想来展示我的组件。就像是:
<body>
<my-component my-decorator></my-component>
</body>
.
@Component(
selector: 'my-component',
templateUrl: '.../my-component.html',
cssUrl: '.../my-component.css',
publishAs: 'comp',
)
class MyComponent {
MyComponent(final Element element) {
Logger.root.fine("MyComponent(): element = $element, element.attributes = ${element.attributes.keys}");
}
}
@Decorator(selector: '[my-decorator]')
class MyDecorator {
final Element element;
@NgOneWay('my-decorator')
var model; // is not used
MyDecorator(this.element) {
Logger.root.fine("MyDecorator(): element = $element, element.nodeName = ${element.nodeName}");
Logger.root.fine("MyDecorator(): element.shadowRoot = ${element.shadowRoot}, element.parent = ${element.parent}");
}
}
不幸的是,它似乎my-decorator
是之前处理过的,my-component
所以它shadowRoot
在注入的Element
对象中获得了 null 属性。
可以检查支持类中my-decorator
属性的存在my-component
,但这显然会污染设计。
更新:感谢 Marko Vuksanovic 的重播,以下内容现在返回:
@Decorator(selector: '[my-decorator]')
class MyDecorator extends AttachAware {
final Element element;
@NgOneWay('my-decorator')
var model; // is not used
MyDecorator(this.element) {
Logger.root.fine("MyDecorator(): element = $element, element.nodeName = ${element.nodeName}");
Logger.root.fine("MyDecorator(): element.shadowRoot = ${element.shadowRoot}, element.parent = ${element.parent}");
}
void attach() {
Logger.root.fine("attach(): element.shadowRoot = ${element.shadowRoot}");
}
}
问题仍然是如何修改 shadow DOM 的样式。
提前感谢您的任何评论/想法/解决方案。