在用户JSON对象中哪里可以找到当前用户信息?

时间:2019-04-20 05:22:08

标签: node.js angular typescript mean-stack

我正在尝试找出如何获取属于当前登录用户的某些数据,例如全名,电子邮件等。

Firefox控制台输出以下内容:

----- header.component.ts -----
this.user:
{}
authService.getUser()
Object { _isScalar: false, source: {…} }
this.authService.me()
Object { _isScalar: false, _subscribe: me() }
-------------------------------

这会打印出使用console.log()提供的authService(请参阅下面的TypeScript代码)。

我浏览了authService.getUser()方法返回的对象以及this.authService.me()方法返回的对象,但是我无法找到任何信息所在的位置。

我在HTML代码中(由Mean.io生成器而不是由我生成的一部分)注意到,它引用“ user.fullname”以在标题栏中显示用户的全名,但是如何?以及您将如何访问其他信息,例如用户的电子邮件,电话号码等?

我的个人资料组件TypeScript文件如下:

import { Component, OnInit, Input } from '@angular/core';
import { Router } from '@angular/router';

import { AuthService } from '../auth/auth.service';

@Component({
  selector: 'app-header',
  templateUrl: './header.component.html',
  styleUrls: ['./header.component.scss']
})
export class HeaderComponent implements OnInit {

  @Input() user: any = {};

  constructor(
    private authService: AuthService,
    private router: Router
  ) { }

  ngOnInit() {
    console.log("----- header.component.ts -----");
    console.log("this.user:");
    console.log(this.user);
    console.log("-------------------------------");
  }

  profile(): void {
    this.navigate('/profile');
  }

  logout(): void {
    this.authService.signOut();
    this.navigate('/auth/login');
  }

  navigate(link): void {
    this.router.navigate([link]);
  }

}

我的个人资料组件HTML文件如下:

<header >
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous">

  <link href="https://fonts.googleapis.com/css?family=ZCOOL+XiaoWei" rel="stylesheet">

  <mat-toolbar color="primary">
    <a [routerLink]="['/']" class="logo"></a>
    <a [routerLink]="['/']" class="toolbar-buttons"> Home </a>
    <a class="toolbar-buttons"> Deals </a>
    <a [routerLink]="['/about']" class="toolbar-buttons"> About </a>

    <span class="example-spacer"></span>
    <a class="links side" [routerLink]="['/auth/login']" *ngIf="!user">Login</a>
    <div>
      <a class="links side" *ngIf="user" [matMenuTriggerFor]="menu">
        <mat-icon>account_circle</mat-icon>{{user.fullname}}
      </a>
      <mat-menu #menu="matMenu">
        <button mat-menu-item *ngIf="user && user.isAdmin" [routerLink]="['/admin']">admin</button>
        <button mat-menu-item (click)="logout()">logout</button>
        <button mat-menu-item (click)="profile()">profile</button>
      </mat-menu>
    </div>
  </mat-toolbar>
</header>

1 个答案:

答案 0 :(得分:1)

事实证明用户并没有立即解决,它等待一些ajax响应,您可以使用ngOnChanges事件,然后像这样访问用户对象

legend("topright", legend=c("y=x^2", "y=1-x^2"),
       col=c("red", "blue"),cex=1,pch=c(15,"#"))