docs: clarify querying all descendants (#15400)
Fixes #14417 Updated example to illustrate @ContentChildren default behavior (only query direct children), and how to query for nested elements/all descendants.
This commit is contained in:
parent
b8d5f87f96
commit
ea848f74af
|
@ -17,13 +17,20 @@ export class Pane {
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'tab',
|
selector: 'tab',
|
||||||
template: `
|
template: `
|
||||||
<div>panes: {{serializedPanes}}</div>
|
<div class="top-level">Top level panes: {{serializedPanes}}</div>
|
||||||
|
<div class="nested">Arbitrary nested panes: {{serializedNestedPanes}}</div>
|
||||||
`
|
`
|
||||||
})
|
})
|
||||||
export class Tab {
|
export class Tab {
|
||||||
@ContentChildren(Pane) panes: QueryList<Pane>;
|
@ContentChildren(Pane) topLevelPanes: QueryList<Pane>;
|
||||||
|
@ContentChildren(Pane, {descendants: true}) arbitraryNestedPanes: QueryList<Pane>;
|
||||||
|
|
||||||
get serializedPanes(): string { return this.panes ? this.panes.map(p => p.id).join(', ') : ''; }
|
get serializedPanes(): string {
|
||||||
|
return this.topLevelPanes ? this.topLevelPanes.map(p => p.id).join(', ') : '';
|
||||||
|
}
|
||||||
|
get serializedNestedPanes(): string {
|
||||||
|
return this.arbitraryNestedPanes ? this.arbitraryNestedPanes.map(p => p.id).join(', ') : '';
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -32,7 +39,12 @@ export class Tab {
|
||||||
<tab>
|
<tab>
|
||||||
<pane id="1"></pane>
|
<pane id="1"></pane>
|
||||||
<pane id="2"></pane>
|
<pane id="2"></pane>
|
||||||
<pane id="3" *ngIf="shouldShow"></pane>
|
<pane id="3" *ngIf="shouldShow">
|
||||||
|
<tab>
|
||||||
|
<pane id="3_1"></pane>
|
||||||
|
<pane id="3_2"></pane>
|
||||||
|
</tab>
|
||||||
|
</pane>
|
||||||
</tab>
|
</tab>
|
||||||
|
|
||||||
<button (click)="show()">Show 3</button>
|
<button (click)="show()">Show 3</button>
|
||||||
|
|
|
@ -12,19 +12,29 @@ import {verifyNoBrowserErrors} from '../../../../../_common/e2e_util';
|
||||||
describe('contentChildren example', () => {
|
describe('contentChildren example', () => {
|
||||||
afterEach(verifyNoBrowserErrors);
|
afterEach(verifyNoBrowserErrors);
|
||||||
let button: ElementFinder;
|
let button: ElementFinder;
|
||||||
let result: ElementFinder;
|
let resultTopLevel: ElementFinder;
|
||||||
|
let resultNested: ElementFinder;
|
||||||
|
|
||||||
beforeEach(() => {
|
beforeEach(() => {
|
||||||
browser.get('/core/di/ts/contentChildren/index.html');
|
browser.get('/core/di/ts/contentChildren/index.html');
|
||||||
button = element(by.css('button'));
|
button = element(by.css('button'));
|
||||||
result = element(by.css('div'));
|
resultTopLevel = element(by.css('.top-level'));
|
||||||
|
resultNested = element(by.css('.nested'));
|
||||||
});
|
});
|
||||||
|
|
||||||
it('should query content children', () => {
|
it('should query content children', () => {
|
||||||
expect(result.getText()).toEqual('panes: 1, 2');
|
expect(resultTopLevel.getText()).toEqual('Top level panes: 1, 2');
|
||||||
|
|
||||||
button.click();
|
button.click();
|
||||||
|
|
||||||
expect(result.getText()).toEqual('panes: 1, 2, 3');
|
expect(resultTopLevel.getText()).toEqual('Top level panes: 1, 2, 3');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should query nested content children', () => {
|
||||||
|
expect(resultNested.getText()).toEqual('Arbitrary nested panes: 1, 2');
|
||||||
|
|
||||||
|
button.click();
|
||||||
|
|
||||||
|
expect(resultNested.getText()).toEqual('Arbitrary nested panes: 1, 2, 3, 3_1, 3_2');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue