Angular中使用JS实现路由跳转、动态路由传值、get方式传值

2021-02-20 22:21

阅读:684

标签:routes   https   path   mod   params   from   str   方式   博客   

场景

Angular介绍、安装Angular Cli、创建Angular项目入门教程:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/105570017

Angular新建组件以及组件之间的调用:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/105694997

通过以上搭建起Angular项目。

Angular中的路由配置、路由重定向、默认选中路由:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/106182994

注:

博客:
https://blog.csdn.net/badao_liumang_qizhi
关注公众号
霸道的程序猿
获取编程相关电子书、教程推送与免费下载。

实现

除了在超链接中进行路由跳转,有时还需要在js中控制进行路由的跳转

JS控制路由跳转

首先在app.routing.module.ts中引入要跳转的组件并配置要跳转的路由

const routes: Routes = [
  {path:parent,component:ParentComponent}
];

然后在页面中添加一个button并添加点击事件

然后在ts中需要引入Router

import {Router} from @angular/router;

并进行声明

constructor(private router:Router) { }

然后在对应的方法中

  goParent()
  {
    this.router.navigate([/parent]);
  }

效果

技术图片

 

 

技术图片

JS控制动态路由

Angular中实现动态路由跳转并传递参数:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/106203529

动态路由的配置同上面一样

在页面新建按钮并设置点击事件

然后在app.routing.module.ts中引入要跳转的组件并配置动态路由

const routes: Routes = [
  {path:newsdetail/:id,component:NewsdetailComponent}

];

在点击事件中

  goDetails()
  {
    this.router.navigate([/newsdetail/,123]);
  }

效果

技术图片

 

 

技术图片

JS控制路由get传值跳转

Angular中实现路由跳转并通过get方式传递参数:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/106203220

配置get传值方式同上。

在页面新建按钮并设置点击事件

除了需要引入Router外还要引入NavigationExtras

import {Router,NavigationExtras} from @angular/router;

然后在app.routing.module.ts中引入要跳转的组件并配置路由

const routes: Routes = [
   {path:newsdetail,component:NewsdetailComponent}
];

在点击事件中

  goDetails2()
  {
    let navigationExtras: NavigationExtras = {
      queryParams: { session_id: 123 },
      fragment: anchor
      };
      
      this.router.navigate([/newsdetail],navigationExtras);
  }

效果

技术图片

 

 

技术图片

Angular中使用JS实现路由跳转、动态路由传值、get方式传值

标签:routes   https   path   mod   params   from   str   方式   博客   

原文地址:https://www.cnblogs.com/badaoliumangqizhi/p/12913851.html


评论


亲,登录后才可以留言!