尽管在 dom 中,但 Angular material2 sidenav 没有显示

use*_*172 5 angular-material2 angular

我有一个问题,sidenav 和 header 是共享服务的不同组件。这在检查 sidenav 元素时似乎有效,我可以看到打开和关闭的切换。我遇到的问题是实际上没有 sidenav 出现。

md-sidenav 没有出现在视觉上,虽然它在 DOM 中

组件文件

import { Component, OnInit, ViewChild } from '@angular/core';

import { MdSidenav } from '@angular/material';

import { SidenavToggleService } from './shared/sidenavToggle.service';

@Component({
  selector: 'app-sidenav',
  templateUrl: './sidenav.component.html',
  styleUrls: ['./sidenav.component.css']
})
export class SidenavComponent implements OnInit {
  @ViewChild('sidenav') sidenav: MdSidenav;

  /**
   * Constructor of the class.
   * @param {sidenavService} SidenavToggleService
   */
  constructor(public sidenavService: SidenavToggleService) {}

  /**
   * OnInit life cycle hook
   */
  public ngOnInit(): void {
    this.sidenavService.setSidenav(this.sidenav);
  }

}
Run Code Online (Sandbox Code Playgroud)

html文件

<md-sidenav-container>
  <md-sidenav #sidenav mode="over">
testerer
  </md-sidenav>
</md-sidenav-container>
Run Code Online (Sandbox Code Playgroud)

服务文件

import { Injectable } from '@angular/core';
import { MdSidenav, MdSidenavToggleResult } from '@angular/material';

@Injectable()
export class SidenavToggleService {
  private sidenav: MdSidenav;

  /**
   * Setter for sidenav.
   *
   * @param {MdSidenav} sidenav
   */
  public setSidenav(sidenav: MdSidenav) {
    this.sidenav = sidenav;
  }

  /**
   * Open this sidenav, and return a Promise that will resolve when it's fully opened (or get rejected if it didn't).
   *
   * @returns Promise<MdSidenavToggleResult>
   */
  public open(): Promise<MdSidenavToggleResult> {
    return this.sidenav.open();
  }

  /**
   * Close this sidenav, and return a Promise that will resolve when it's fully closed (or get rejected if it didn't).
   *
   * @returns Promise<MdSidenavToggleResult>
   */
  public close(): Promise<MdSidenavToggleResult> {
    return this.sidenav.close();
  }

  /**
   * Toggle this sidenav. This is equivalent to calling open() when it's already opened, or close() when it's closed.
   *
   * @param {boolean} isOpen  Whether the sidenav should be open.
   *
   * @returns {Promise<MdSidenavToggleResult>}
   */
  public toggle(isOpen?: boolean): Promise<MdSidenavToggleResult> {
    console.log('uh');
    return this.sidenav.toggle(isOpen);
  }
}
Run Code Online (Sandbox Code Playgroud)

编辑:添加了我正在使用的服务

use*_*172 1

我不得不将工具栏组件包装在 sidenav-container 中......

<div >
  <md-sidenav-container>
  <app-header></app-header>
  <app-sidenav></app-sidenav>
  </md-sidenav-container>
  test
</div>
Run Code Online (Sandbox Code Playgroud)

我不知道为什么我必须这样做,但现在可以了。我现在必须在职位等方面工作。