[英]Call sidenav component from toolbar component in angular-material2
How to call left sidenav from a header toolbar component? 如何从标题工具栏组件调用left sidenav?
header-toolbar.component.ts 报头toolbar.component.ts
import {Component, ViewChild} from "@angular/core";
@Component({
selector: 'header-toolbar',
templateUrl: './app/header-toolbar/header-toolbar.component.html',
})
export class HeaderToolbarComponent{ }
header-toolbar.component.html 报头toolbar.component.html
<md-sidenav-layout>
<left-sidenav #s [sidenavFromLeftSideComponent]="s"></left-sidenav>
<md-sidenav-layout>
<md-toolbar color="primary">
<button md-icon-button (click)="s.toggle()">
<i class="material-icons">menu</i>
</button>
<span>Project name</span>
</md-toolbar>
</md-sidenav-layout>
</md-sidenav-layout>
left-sidenav.component.ts 左sidenav.component.ts
import {Component, Input} from "@angular/core";
@Component({
selector: 'left-sidenav',
templateUrl: './app/left-sidenav/left-sidenav.component.html'
})
export class LeftSidenavComponent{
@Input() sidenavFromLeftSideComponent: any;
}
left-sidenav.component.html 左sidenav.component.html
<md-sidenav #sidenav>
<button md-button (click)="sidenav.close()">Close</button>
</md-sidenav>
Thanks. 谢谢。
PS I'm new in angular. PS我是新手。
A layout example for you, you could use template variable combine with Input
to do this. 对于您的布局示例,您可以将模板变量与Input
结合使用来执行此操作。
app.component.html app.component.html
<md-sidenav-layout>
<header-bar [leftnav]=left [rightnav]=right></header-bar>
<breadcrumbs></breadcrumbs>
<md-sidenav #left mode="over">
<left-side-nav [leftnav]=left></left-side-nav>
</md-sidenav>
<md-sidenav #right align="end" mode="side">
<right-side-nav [rightnav]=right></right-side-nav>
</md-sidenav>
<router-outlet></router-outlet>
</md-sidenav-layout>
<footer-bar></footer-bar>
header.component.ts header.component.ts
import { Component } from '@angular/core';
@Component({
selector: 'header-bar',
styleUrls: ['header.component.css'],
templateUrl: 'header.component.html'
})
export class HeaderComponent {
@Input() leftnav;
@Input() rightnav;
}
header.component.html header.component.html
<md-toolbar>
<button md-icon-button (click)="leftnav.toggle()">
<md-icon>menu</md-icon>
</button>
</md-toolbar>
now you could click menu
button in header to toggle sidenav. 现在您可以单击标题中的menu
按钮来切换sidenav。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.