Angular刷新当前页面的实现方法


Posted in Javascript onNovember 21, 2018

onSameUrlNavigation

从angular5.1起提供onSameUrlNavigation来支持路由重新加载。

有两个值'reload'和'ignore'。默认为'ignore'

定义当路由器收到一个导航到当前 URL 的请求时应该怎么做。 默认情况下,路由器将会忽略这次导航。但这样会阻止类似于 "刷新" 按钮的特性。 使用该选项可以配置导航到当前 URL 时的行为。

使用

配置onSameUrlNavigation

@NgModule({
 imports: [RouterModule.forRoot(
  routes,
  { onSameUrlNavigation: 'reload' }
 )],
 exports: [RouterModule]
})

reload实际上不会重新加载路由,只是重新出发挂载在路由器上的事件。

配置runGuardsAndResolvers

runGuardsAndResolvers有三个值:

  • paramsChange: 仅在路由参数更改时触发。如/reports/:id 中id更改
  • paramsOrQueryParamsChange: 当路由参数更改或参训参数更改时触发。如/reports/:id/list?page=23中的id或page属性更改
  • always :始终触发
const routes: Routes = [
 {
  path: '',
  children: [
   { path: 'report-list', component: ReportListComponent },
   { path: 'detail/:id', component: ReportDetailComponent, runGuardsAndResolvers: 'always' },
   { path: '', redirectTo: 'report-list', pathMatch: 'full' }
  ]
 }
];

组件监听router.events

import {Component, OnDestroy, OnInit} from '@angular/core';
import {Observable} from 'rxjs';
import {Report} from '@models/report';
import {ReportService} from '@services/report.service';
import {ActivatedRoute, NavigationEnd, Router} from '@angular/router';

@Component({
 selector: 'app-report-detail',
 templateUrl: './report-detail.component.html',
 styleUrls: ['./report-detail.component.scss']
})
export class ReportDetailComponent implements OnInit, OnDestroy {
 report$: Observable<Report>;
 navigationSubscription;

 constructor(
  private reportService: ReportService,
  private router: Router,
  private route: ActivatedRoute
 ) {
  this.navigationSubscription = this.router.events.subscribe((event: any) => {
   if (event instanceof NavigationEnd) {
    this.initLoad(event);
   }
  });
 }

 ngOnInit() {
  const id = +this.route.snapshot.paramMap.get('id');
  this.report$ = this.reportService.getReport(id);
 }

 ngOnDestroy(): void {
  // 销毁navigationSubscription,避免内存泄漏
  if (this.navigationSubscription) {
   this.navigationSubscription.unsubscribe();
  }
 }

 initLoad(e) {
  window.scrollTo(0, 0);
  console.log(e);
 }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
解决AJAX中跨域访问出现'没有权限'的错误
Aug 20 Javascript
扩展Jquery插件处理mouseover时内部有子元素时发生样式闪烁
Dec 08 Javascript
js实现浏览器窗口大小被改变时触发事件的方法
Feb 02 Javascript
将JavaScript的jQuery库中表单转化为JSON对象的方法
Nov 17 Javascript
js严格模式总结(分享)
Aug 22 Javascript
canvas压缩图片转换成base64格式输出文件流
Mar 09 Javascript
vue-cli项目如何使用vue-resource获取本地的json数据(模拟服务端返回数据)
Aug 04 Javascript
微信小程序组件之srcoll-view的详解
Oct 19 Javascript
Bootstrap实现翻页效果
Nov 27 Javascript
vue裁切预览组件功能的实现步骤
May 04 Javascript
JavaScript封装的常用工具类库bee.js用法详解【经典类库】
Sep 03 Javascript
vue中通过使用$attrs实现组件之间的数据传递功能
Sep 01 Javascript
详解ES6系列之私有变量的实现
Nov 21 #Javascript
jQuery实现上下滚动公告栏详细代码
Nov 21 #jQuery
Vue.js 中 axios 跨域访问错误问题及解决方法
Nov 21 #Javascript
vue  directive定义全局和局部指令及指令简写
Nov 20 #Javascript
详解Vue.js在页面加载时执行某个方法
Nov 20 #Javascript
element vue validate验证名称重复 输入框与后台重复验证 特殊字符 字符长度 及注意事项小结【实例代码】
Nov 20 #Javascript
jQuery 同时获取多个标签的指定内容并储存为数组
Nov 20 #jQuery
You might like
php 遍历数据表数据并列表横向排列的代码
2009/09/05 PHP
php提示undefined index的几种解决方法
2012/05/21 PHP
php多层数组与对象的转换实例代码
2013/08/05 PHP
php计算程序运行时间的简单例子分享
2014/05/10 PHP
PHP判断JSON对象是否存在的方法(推荐)
2016/07/06 PHP
关于php 高并发解决的一点思路
2017/04/16 PHP
Laravel框架使用Seeder实现自动填充数据功能
2018/06/13 PHP
JS BASE64编码 window.atob(), window.btoa()
2021/03/09 Javascript
原生JavaScript实现连连看游戏(附源码)
2013/11/05 Javascript
基于javascript实现的搜索时自动提示功能
2014/12/26 Javascript
thinkphp 表名 大小写 窍门
2015/02/01 Javascript
详解nodejs与javascript中的aes加密
2016/05/22 NodeJs
javascript简单进制转换实现方法
2016/11/24 Javascript
详解微信小程序入门五: wxml文件引用、模版、生命周期
2017/01/20 Javascript
原生js实现吸顶效果
2017/03/13 Javascript
Vue 中mixin 的用法详解
2018/04/23 Javascript
Elasticsearch实现复合查询高亮结果功能
2019/09/10 Javascript
IE11下CKEditor在Bootstrap Modal中下拉问题的解决
2019/09/25 Javascript
JSON获取属性值方法代码实例
2020/06/30 Javascript
浅谈vue项目利用Hbuilder打包成APP流程,以及遇到的坑
2020/09/12 Javascript
17个Python小技巧分享
2015/01/23 Python
Python实现方便使用的级联进度信息实例
2015/05/05 Python
Python3.6简单反射操作示例
2018/06/14 Python
CSS的pointer-events属性详细介绍(作用和注意事项)
2014/04/23 HTML / CSS
移动端HTML5 input常见问题(小结)
2020/09/28 HTML / CSS
优秀的茶餐厅创业计划书
2014/01/03 职场文书
大学生写自荐信的技巧
2014/01/08 职场文书
金融管理专业求职信
2014/07/10 职场文书
基层党支部整改方案
2014/10/25 职场文书
2014年企业党建工作总结
2014/12/18 职场文书
电信营业员岗位职责
2015/04/14 职场文书
2015年采购员工作总结
2015/04/27 职场文书
应届生个人的求职(自荐信范文2篇)
2019/08/23 职场文书
详解python的内存分配机制
2021/05/10 Python
解决Swagger2返回map复杂结构不能解析的问题
2021/07/02 Java/Android
Go 通过结构struct实现接口interface的问题
2021/10/05 Golang