在Angular中,可以使用路由守卫来加载用户信息并存储在本地存储中。在每个组件中,都可以使用ngOnInit钩子函数来检查本地存储中是否存在用户信息,并根据需要使用它来渲染组件。
下面是一个简单的示例:
import { Injectable } from '@angular/core';
@Injectable({ providedIn: 'root' }) export class UserService { private user: any;
setUser(user: any) { this.user = user; localStorage.setItem('user', JSON.stringify(user)); }
getUser() { if (!this.user) { this.user = JSON.parse(localStorage.getItem('user') || '{}'); } return this.user; } }
import { Injectable } from '@angular/core'; import { CanActivate, ActivatedRouteSnapshot, RouterStateSnapshot, Router } from '@angular/router'; import { UserService } from './user.service';
@Injectable({ providedIn: 'root' }) export class AuthGuard implements CanActivate { constructor(private userService: UserService, private router: Router) {}
canActivate(next: ActivatedRouteSnapshot, state: RouterStateSnapshot) { const user = JSON.parse(localStorage.getItem('user') || '{}'); this.userService.setUser(user);
if (user) {
return true;
} else {
this.router.navigate(['/login']);
return false;
}
} }
import { Component, OnInit } from '@angular/core'; import { UserService } from '../user.service';
@Component({ selector: 'app-profile', templateUrl: './profile.component.html', styleUrls: ['./profile.component.css'] }) export class ProfileComponent implements OnInit { user: any;
constructor(private userService: UserService) {}
ngOnInit() { this.user = this.userService.getUser(); } }
现在,当用户登录后,其信息将被保存在本地存储中。当页面刷新时,路由守卫将从本地存储中加载