Angular16如何获得路由参数

Anguar 16 引入一个有趣的功能,可以将路由器数据直接通过 @Input 来绑定,例如:QueryString,路由参数,data 静态数据。

旧写法

在 Angular 16 之前,需要通过 ActivatedRoute 来获取这些数据。假设有这么一个路由配置:

{ 
  path: ':type', 
  component: TestComponent,
  data: { role: 'admin' }
}

并通过以下访问路由时:

/weixin?uid=1&allow=false

我们可以透过注入 ActivatedRoute 并分别从 dataparamsqueryParams 获取到所需要的数据。

倘若,你想监听 params 数据的变化,还需要单独为订阅处理;

除此之外,除 data 以外,其他数据类型都是自动转成 string,反正到这里我已经很烦人了。

新方式

从 Angular 16 开始这些参数都可以自动绑定到 @Input 输入参数当中。可以通过 bindToComponentInputs 激活这个有趣的新功能,就像这样:

RouterModule.forRoot(routes, {
  bindToComponentInputs: true
});

# Sandalone 版本
provideRouter([], withComponentInputBinding())

写法也非常简单:

@Input() type = '';
@Input() role = '';
@Input({ transform: numberAttribute }) uid = 0;
@Input({ transform: booleanAttribute }) allow = false;

注:transform 参数是 Angular 16.1 以上新的改进,可以极大的简化编写 getset

当然,当路由发生变更时 @Input 也会自动更新,你可以通过 ngOnChanges 来知晓,也可以利用 getset 写法。

Happy coding!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 路由与导航 在用户使用应用程序时,Angular 的路由器能让用户从一个视图导航到另一个视图。 导入路由 Angu...
    salt_fash阅读 591评论 0 2
  • 这里给大家简单的总结下Angular2路由器相关的一些信息。但是我一向认为最好的文档还是官方文档,还是推荐大...
    tuacy阅读 2,869评论 0 3
  • 一.课程简介 (注意:这里的AngularJS指的是2.0以下的版本) AngularJS的优点: 模板功能强大丰...
    壹点微尘阅读 951评论 0 0
  • 路由:根据不同地址加载不同组件,实现单页面应用 # 1 路由基础知识 ================= 在ang...
    __凌阅读 709评论 0 0
  • Angular7入门总结篇 6 2019.01.08 19:34:05 字数 4854阅读 46093 发表于 h...
    痞_4fc8阅读 1,531评论 0 5