我试图用Renderer.selectRootElement摆脱我的组件的一些元素,如所描述这里.
除非我只选择一个元素(plnkr),否则一切正常.
如您所见,我创建了一个组件:
export class ExampleComponent implements OnInit{
@Input() start: any;
@Input() end: any;
constructor(public _renderer:Renderer){
};
ngOnChanges(){
}
ngOnInit(){
console.log("NG ON CHAN START DATE",this.start);
console.log("NG ON INIT END DATE",this.end);
var container = this._renderer.selectRootElement('.container');
console.log(container);
var inner1 = this._renderer.selectRootElement('.inner1');
console.log(inner1);
var inner2 = this._renderer.selectRootElement('.inner2');
console.log(inner2);
}
}
Run Code Online (Sandbox Code Playgroud)
当我尝试运行它时,我有一个错误:
EXCEPTION:选择器".inner1"与MainViewComponent @ 3:65中[{{exampleData.end}}中的任何元素都不匹配]
(但是,在我的应用程序中,当只找到第一个容器时,则找不到其他容器).
这有什么想法来自哪里?
UPDATE
我发现该指令未被完全调用 - 只有带有类的div container被添加到HTML中.
Eri*_*nez 27
其目的不是在组件视图中按选择器选择随机元素.
只需在DomRootRenderer中查看其实现
selectRootElement(selector: string): Element {
var el = DOM.querySelector(this._rootRenderer.document, selector);
if (isBlank(el)) {
throw new BaseException(`The selector "${selector}" did not match any elements`);
}
DOM.clearNodes(el);
return el;
}
Run Code Online (Sandbox Code Playgroud)
你看到有趣的东西吗?它正在删除元素内的节点!为什么会这样做?因为它的目的是抓住根元素!那么哪一个是根元素?这听起来很熟悉吗?
<my-app>
Loading...
</my-app>
Run Code Online (Sandbox Code Playgroud)
是! 那是根本要素.那好吧,但如果我只想抓住元素,那么使用selectRootElement有什么问题?它返回没有子元素的元素,视图中没有任何变化!好吧,当然你仍然可以使用它,但是你将会像人们一样使用DynamicComponentLoader#loadAsRoot手动订阅EventEmitter 来击败它的目的并滥用它.
嗯,毕竟它的名字,selectRootElement几乎说它做了什么,不是吗?
您有两种方法可以抓取视图中的元素,以及两个正确的选项.
<div #myElement>...</div>
@ViewChild('myElement') element: ElementRef;
ngAfterViewInit() {
// Do something with this.element
}
Run Code Online (Sandbox Code Playgroud)
@Directive({
selector : '.inner1,inner2' // Specify all children
// or make one generic
// selector : '.inner'
})
class Children {}
template : `
<div class="container">
<div class="inner1"></div>
<div class="inner2"></div>
<!-- or one generic
<div class="inner"></div>
<div class="inner"></div>
-->
</div>
`
class Parent (
@ViewChildren(Children) children: QueryList<Children>;
ngAfterViewInit() {
// Do something with this.children
}
)
Run Code Online (Sandbox Code Playgroud)
如果要保留内容,请使用第二个布尔参数 to true,如下所示:(使用 Angular 6)
let activeLi = this.renderer.selectRootElement('ul.ddl>li.active', true);
Run Code Online (Sandbox Code Playgroud)
从 API 查看详细信息
/*
* Implement this callback to prepare an element to be bootstrapped
* as a root element, and return the element instance.
* @param selectorOrNode The DOM element.
* @param preserveContent Whether the contents of the root element
* should be preserved, or cleared upon bootstrap (default behavior).
* Use with `ViewEncapsulation.ShadowDom` to allow simple native
* content projection via `<slot>` elements.
* @returns The root element.
*/
Run Code Online (Sandbox Code Playgroud)
抽象 selectRootElement(selectorOrNode: string | any, preserveContent?: boolean ): any;
感谢 Eric 通知它默认删除内容!
| 归档时间: |
|
| 查看次数: |
10738 次 |
| 最近记录: |