angular - 如何将路由事件 URL 绑定到 Angular 中的 HTML 模板
问题描述
我有一个角度组件,我试图在其中绑定一个基于路由器 URL 的公共变量。公共变量在 subscribe 方法中被赋值,因此模板在初始加载时不会更新。
pageTitle: string;
constructor(private router: Router) {}
ngOnInit() {
this.router.events.subscribe((event) => {
if (event instanceof NavigationEnd) {
if(event.url ==="something" {
this.pageTitle ="About US"
}
}
})
}
我在 HTML 文件中绑定pageTitle变量
<div class="title">{{pageTitle}}</div>
刷新页面时,我可以看到 pageTitle,但在初始加载时未显示该值。
解决方案
如果您的 pageTitle 发生更改,您应该尝试使其可观察并使用async
管道处理以使其保持最新
添加了 Stackblitz 实现:https ://stackblitz.com/edit/angular-scdiic
尝试这样的事情
this.title = this.route.events.pipe(
filter(event => event instanceof NavigationEnd),
map((event: NavigationEnd) => event.url));
<div class="title">{{pageTitle | async}}</div>
也为了更好地了解变化检测如何在 Angular 中工作,如下所示:https ://auth0.com/blog/understanding-angular-2-change-detection/以获得良好的开端
推荐阅读
- javascript - 在 reactjs 中使用 .filter 输出项目的长度
- ios - Apple App Store - 待定协议状态
- php - 如何在循环中将元素推送到数组
- sqlite - sqlite中的隐式转换是如何发生的?
- c# - 如何读取另一个项目的 app.config 文件
- asp.net - 什么是 dotnet 主机版本?
- javascript - Angular HttpClient 响应与导航器预览不同,特殊字符未解码
- c - 编译器不断重复打印语句 - C 语言编程
- python - Python Flask REST API 在调用子进程命令期间冻结
- javascript - 在js中单击按钮时传递变量