AngularRouter:使用带有参数的loadChildren无法传递参数问题。
创始人
2024-10-29 06:00:59
0

在Angular中,我们可以使用路由器导航到不同的组件或文件。路由器导航通常将参数传递给组件。loadChildren 是一个在 Angular 路由器中使用的函数,可以将懒加载模块加载到应用程序中,并在该模块中注册组件。

然而,在使用 loadChildren 函数时,无法直接传递参数。这样会导致在接收参数时出现问题。这时候我们需要通过一个针对该问题的修改来解决。

首先,我们可以将懒加载模块的路由制成根路径,如下:

const appRoutes: Routes = [
  { path: '', redirectTo: 'home', pathMatch: 'full' },
  { path: 'home', component: HomeComponent },
  { path: 'about', component: AboutComponent },
  { path: 'users/:id', loadChildren: () => import('./user/user.module').then(m => m.UserModule) },
];

然后我们需要在模块中使用路径路径来接收参数。在模块中,我们使用 forChild 函数来定义路由。如下:

const userRoutes: Routes = [
  {
    path: '',
    component: UserComponent,
    children: [
      { path: '', component: UserListComponent },
      { path: 'add', component: UserAddComponent },
      { path: ':id', component: UserDetailComponent },
    ]
  }
];

@NgModule({
  imports: [RouterModule.forChild(userRoutes)],
  exports: [RouterModule]
})
export class UserRoutingModule { }

接下来我们可以在组件中通过 ActivatedRoute 来获取参数。ActivatedRoute 是 Angular 路由器中的一个服务,用于监控和获取当前路由。

例如,我们可以在 UserDetailComponent 组件中获取参数,如下:

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

@Component({
  selector: 'app-user-detail',
  templateUrl: './user-detail.component.html',
  styleUrls: ['./user-detail.component.css']
})
export class UserDetailComponent implements OnInit {
  userId: any;

  constructor(private route: ActivatedRoute) { }

  ngOnInit() {
    this.route.params.subscribe(params => {
      this.userId = params['id'];
    });
  }
}

这样就可以通过 loadChildren 函数和 ActivatedRoute 服务来解决问题了。

相关内容

热门资讯

微信小程序黑科技免费!微乐小程... 微信小程序黑科技免费!微乐小程序外辅助工具(开挂)神器-好像揭露真的是有挂1、模拟器是什么优化,俱乐...
微乐小程序透视辅助!微信小程序... 微乐小程序透视辅助!微信小程序微乐家乡辅助器(开挂)app-确实详情是有挂1、下载好脚本下载之后点击...
微信小程序黑科技免费!如何下载... 微信小程序黑科技免费!如何下载微乐自建房黑科技入口(开挂)挂-其实揭露存在有挂1. 选牌创建新账号,...
微乐小程序黑科技!微乐小程序游... 微乐小程序黑科技!微乐小程序游戏破解器苹果系统(开挂)器-原来教你存在有挂透视方法中分为三种模型:靠...
微信小程序微乐破解器!微信小程... 微信小程序微乐破解器!微信小程序微乐辅助器破解版(开挂)脚本-其实揭幕真的有挂1、免费脚本咨询教程、...
微乐小程序黑科技!微信微乐游戏... 微乐小程序黑科技!微信微乐游戏苹果辅助器(开挂)教程-果然关于真的是有挂1、起透看视 辅助软件价格2...
微乐小程序真的有挂!微信小程序... 微乐小程序真的有挂!微信小程序微乐辅助器app(开挂)器-果然推荐有挂1、全新机制【ai辅助工具激活...
微乐小程序存在有挂!微乐家乡a... 微乐小程序存在有挂!微乐家乡app辅助器(开挂)挂-切实总结真的是有挂透视方法中分为三种模型:靠谱、...
微乐小程序黑科技免费!微信小程... 微乐小程序黑科技免费!微信小程序微乐破解填大坑(开挂)软件-都是开挂真的是有挂一、可以开透视的定义与...
微乐小程序透视挂!小程序微乐辅... 微乐小程序透视挂!小程序微乐辅助软件(开挂)插件-确实解谜真的有挂1、打开软件启动之后找到中间准星的...