我有一个Angular 2模块,我在其中实现了路由,并希望在导航时存储状态.用户应该能够:1.使用搜索公式搜索文档2.导航到其中一个结果3.导航回searchresult - 无需与服务器通信
这可能包括RouteReuseStrategy.问题是:如何实现不应存储文档?
那么应该存储路径路径"文档"的状态,并且不应存储路径路径"documents /:id"'状态?
在Angular2中,有没有办法更新矩阵参数,但导航到同一个组件?基本上想要从一个看起来像这样的网址轻松过渡:
/search;term=paris;pageSize=24;currentPage=1;someFilter=value;
同样的事情,但在分页时更新currentPage:
/search;term=paris;pageSize=24;currentPage=2;someFilter=value;
使用router.navigate似乎并不是最佳选择,因为我必须编写大量自己的逻辑来重新构建用于navigate使用的URL (重新构建已经存在的东西).
对于踢腿和咯咯笑,我确实尝试过
this._router.navigate([this._router.url, {currentPage: this.pagination.currentPage}]);
但是(正如你所料),路由器对于当前网址上有矩阵参数这一事实是愚蠢的,所以结果不是很好.
编辑:还应该提到可能有任意数量的矩阵参数的附加键/值对,因此硬编码任何路由都是不可能的
编辑:我以后尝试使用preserveQueryParams: true像:
this._router.navigate(["..", {currentPage: this.pagination.currentPage}], {preserveQueryParams: true});
为了获得一个易于使用/可转移的解决方案,但这并没有保持路线上的矩阵参数.
更新:我已经实现了自己的逻辑来获得所需的行为,所以这里是解决方案的代码片段:
let currentParamsArr: Params = this.route.snapshot.params;
let currentParamsObj: any = { };
for (let param in currentParamsArr) {
currentParamsObj[param] = currentParamsArr[param];
}
currentParamsObj.currentPage = +pageNum; //typecasting shortcut
this._router.navigate([currentParamsObj], { relativeTo: this.route });
Run Code Online (Sandbox Code Playgroud)
这段代码循环遍历参数(因为它们位于快照中),并从中创建一个对象,然后添加/编辑我想要更新的参数,然后导航到"新"路径
但是,这并不漂亮,因为我在程序的许多地方基本上都有相同的逻辑,或者必须对路由器进行修改或提供其他一些通用方法.