浅析Angular路由中navigateByUrl和navigate的区别和共同点
时间:2021-11-18
来源:互联网
标签:
今天PHP爱好者给大家带来本篇文章给大家对比一下Angular路由中navigateByUrl和navigate,看看他们的不同点和共同点,希望对大家有所帮助!

angular navigateByUrl vs navigate 路由跳转
import { Router, ActivatedRoute } from '@angular/router';
export class xxx{
constructor(private router: Router, private route: ActivatedRoute){}
}
1. 不同点
1.1 navigateByUrl()
navigateByUrl(url: string | UrlTree, extras: NavigationExtras = { skipLocationChange: false }): Promise<boolean>
第一个参数必须是==绝对路径==的字符串。
this.router.navigateByUrl('/home');
他俩接收的第一个参数不同,第二个参数相同。
1.2 navigate()
navigate(commands: any[], extras: NavigationExtras = { skipLocationChange: false }): Promise<boolean>
第一个参数是一个数组
this.router.navigate(['home', 'demo'])
那么解析的路由就是localhost:4200/home/demo。
可以相对当前路由进行导航
传入一个relativeTo参数,即可相对传入的路由进行跳转。如当前在localhost:4200/home,
this.router.navigate(['demo'], {relativeTo: this.route})
跳转后的地址为localhost:4200/home/demo。
但如果'demo'写成'/demo'传入的路由就不起作用了,会以根路由进行导航。如果不传入也是默认以根路由(localhost:4200)进行导航。
2. 共同点:
interface NavigationExtras {
relativeTo?: ActivatedRoute | null
queryParams?: Params | null
fragment?: string
preserveQueryParams?: boolean
queryParamsHandling?: QueryParamsHandling | null
preserveFragment?: boolean
skipLocationChange?: boolean
replaceUrl?: boolean
state?: {...}
}
2.1 传递参数方式一样
以 navigate 举例
通过queryParams传参
此种传参方式会把参数拼接在url上,如localhost:4200/demo?id=1
A组件传递参数
this.router.navigate(['demo'], {queryParams: {id: 1} , relativeTo: this.route})
B组件接收参数
若是通过
/user/:id方式传递过来用activatedRoute.params
import { ActivatedRoute } from '@angular/router';
constructor(private activatedRoute: ActivatedRoute) {
this.activatedRoute.params.subscribe((param) => {
console.log('组件里面的param', param);// {id :1}
});
}
若是通过
/user?id=1方式传递用activatedRoute.queryParams
import { ActivatedRoute } from '@angular/router';
constructor(private activatedRoute: ActivatedRoute) {
this.activatedRoute.queryParams.subscribe((param) => {
console.log('组件里面的queryParams', param); // {id :1}
});
}
通过state传参
此种方式会把数据存在浏览器的历史记录中,state必须是一个对象,在子路由中使用getCurrentNavigation取出。
A组件传递参数
import { Component, Input } from '@angular/core';
import { Router, NavigationExtras } from '@angular/router';
@Component({
selector: 'a-component',
template: `
<button (click)="test()">Test</button>
`,
})
export class AComponent {
constructor(private router: Router){}
test(){
const navigationExtras: NavigationExtras = {state: {id: 1}};
this.router.navigate(['b'], navigationExtras);
}
}
B组件接收参数
import { Component } from '@angular/core';
import { Router } from '@angular/router';
@Component({
selector: 'b-component'
})
export class BComponent {
constructor(private router: Router) {
const navigation = this.router.getCurrentNavigation();
const state = navigation.extras.state as {id: number};
// state.id 就是传过来的数据
}
}
2.2 均有回调
this.router.navigate(['demo']).then(nav => {
console.log(nav); // true: 跳转成功, false 跳转失败
}, err => {
console.log(err) // 发生无措
});
更多用法更新于 github:
https://github.com/deepthan/blog-angular
以上就是浅析Angular路由中navigateByUrl和navigate的区别和共同点的详细内容,更多请关注php爱好者其它相关文章!
-
什么是AP隔离?AP隔离开关有什么用 时间:2025-12-17 -
AP隔离在哪里设置 AP隔离开启还是关闭好 时间:2025-12-17 -
USB Host接口有什么用?USB Host和USB Device接口的区别 时间:2025-12-16 -
HDMI怎么区分1.4和2.0?HDMI1.4和2.0的区别 时间:2025-12-16 -
com.android.phone已停止运行是什么意思?怎么解决? 时间:2025-12-16 -
4mp摄像头是多少像素?4mp和1080p有什么区别? 时间:2025-12-16
今日更新
-
暴风影音手机版官网下载-暴风影音官方手机版入口
阅读:18
-
steam官网下载入口-手把手教你安装steam
阅读:18
-
欧易官方客服联系方式及防诈骗指南 安全咨询必备
阅读:18
-
韩漫YY漫画登录入口-韩漫YY漫画官网登录通道
阅读:18
-
炮座梗是什么梗?揭秘网络热词炮座梗的爆笑起源和用法,看完秒懂!
阅读:18
-
我的门派12个最新兑换码礼包合集
阅读:18
-
欧易L1身份验证全攻略 快速完成认证步骤
阅读:18
-
英语CET4国际版成绩快速查询入口-英语CET4港澳台专属通道查询入口
阅读:18
-
魔兽世界大脚插件官网秒开入口-大脚插件官网最新地址一键直达
阅读:18
-
充币未到账解决方法 快速处理带标签充币问题指南
阅读:18










