简体   繁体   English

从angular-material2的工具栏组件中调用sidenav组件

[英]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>
            &nbsp;
            <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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM