• navigate


    一、router.navigate的使用

    navigate是Router类的一个方法,主要用来跳转路由。 

    函数定义:

    1
    navigate(commands: any[], extras?: NavigationExtras) : Promise`<boolean>`
    1
    2
    3
    4
    5
    6
    7
    8
    9
    interface NavigationExtras {
     relativeTo : ActivatedRoute
     queryParams : Params
     fragment : string
     preserveQueryParams : boolean
     preserveFragment : boolean
     skipLocationChange : boolean
     replaceUrl : boolean
    }

    1.this.router.navigate(['user', 1]); 

    以根路由为起点跳转

    2.this.router.navigate(['user', 1],{relativeTo: route}); 

    默认值为根路由,设置后相对当前路由跳转,route是ActivatedRoute的实例,使用需要导入ActivatedRoute

    3.this.router.navigate(['user', 1],{ queryParams: { id: 1 } }); 
    路由中传参数 /user/1?id=1

    4.this.router.navigate(['view', 1], { preserveQueryParams: true }); 

    默认值为false,设为true,保留之前路由中的查询参数/user?id=1 to /view?id=1

    5.this.router.navigate(['user', 1],{ fragment: 'top' }); 

    路由中锚点跳转 /user/1#top

    6.this.router.navigate(['/view'], { preserveFragment: true }); 

    默认值为false,设为true,保留之前路由中的锚点/user/1#top to /view#top

    7.this.router.navigate(['/user',1], { skipLocationChange: true }); 

    默认值为false,设为true路由跳转时浏览器中的url会保持不变,但是传入的参数依然有效

    8.this.router.navigate(['/user',1], { replaceUrl: true }); 

    未设置时默认为true,设置为false路由不会进行跳转

    二、router.navigate刷新页面问题

    造成这个问题一般是因为我们在<form>表单中使用<button>时忘记添加type属性,在表单中,如果忘记给按钮添加属性,会默认为submit

    1
    <button (click)="toDetail()">detail</button>
    1
    2
    3
    toDetail() {
     this._router.navigate(['/detail']);
    }

    解决方法: 

    1.添加type

    1
    <button type="button" (click)="toDetail()">detail</button>

    2.click添加false

    1
    <button (click)="toDetail();false">detail</button>

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者使用Angular.js能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

  • 相关阅读:
    《你的知识需要管理》——田志刚
    《谁动了我的奶酪》——[美]斯宾塞·约翰逊
    《程序员面试宝典(第三版)》——欧立奇 / 刘洋 / 段韬
    《天才在左疯子在右》——高铭
    LintCode: Combination Sum
    LintCode: Flatten Binary Tree to Linked List
    LintCode: First Position of Target
    LintCode: Delete Node in the Middle of Singly Linked List
    LintCode: Maximum Depth of Binary Tree
    pytorch visdom可视化工具学习—3-命令行操作使用经验
  • 原文地址:https://www.cnblogs.com/jayruan/p/7674590.html
Copyright © 2020-2023  润新知