首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用路由离子4传递对象

用路由离子4传递对象
EN

Stack Overflow用户
提问于 2019-01-09 08:13:16
回答 3查看 2.8K关注 0票数 0

我对离子4很陌生,我想把一个物体从一个屏幕传递到另一个屏幕。我的第一个屏幕是screen1,我想将“screen1”类型的"model“对象传递给screen2。

目前,我正在使用下面的代码从我的screen1导航到screen2。

This.router.navigateByUrl(‘屏幕2/’);

如何通过这个路径传递“模型”对象?

我在谷歌上搜索了一个解决方案,但没有发现任何与我的问题相关的问题。我只发现一件事,我们可以通过URL传递数据,使用queryparams,但是我想保持数据的私有性,而不想在URL中显示数据。

谁知道,我怎么能这么做?

EN

回答 3

Stack Overflow用户

发布于 2019-01-09 08:38:20

我对你的建议是实现一个解析器

看看我的演示 at StackBlitz,看看它的实际效果。

实现解析器:

代码语言:javascript
复制
@Injectable()
class TeamResolver implements Resolve<Team> {
  constructor(private myService: MyService) {}

  resolve(
    route: ActivatedRouteSnapshot,
    state: RouterStateSnapshot
  ): Observable<any>|Promise<any>|any {
    // return the data you need in your component using your service 
    // route params will sit in - route.params.id
  }
}

宣布:

代码语言:javascript
复制
@NgModule({
  imports: [
    RouterModule.forRoot([
      {
        path: 'team/:id',
        component: TeamCmp,
        resolve: {
          team: TeamResolver
        }
      }
    ])
  ],
  providers: [TeamResolver]
})
class AppModule {}

使用它:

代码语言:javascript
复制
@Component({
  ...
})
export class TeamCmp {
  constructor(private activatedRoute: ActivatedRoute) {
    // the data sits here - this.activatedRoute.snapshot.data;
  }
}
票数 1
EN

Stack Overflow用户

发布于 2019-04-10 05:34:03

您只需使用路由器导航就可以做到这一点

代码语言:javascript
复制
    this.router.navigate(['screen2', {modelName: model}]);

并由ActivatedRoute接收

代码语言:javascript
复制
    this.activatedRoute.snapshot.paramMap.get('modelName');
票数 0
EN

Stack Overflow用户

发布于 2020-04-22 04:04:57

由于您的问题是“我如何从一个页面发送东西到另一个页面”,解决方案不必局限于使用路由器:另一个选择是使用存储。

代码语言:javascript
复制
import { Router } from '@angular/router';
import { Storage } from '@ionic/storage';

blah() {
    this.storage.set('importantThing', this.importantThing);
    this.router.navigateByUrl('my-page/new-subpage');
}

然后在接收页面中:

代码语言:javascript
复制
await this.storage.get('importantThing').then(result => {
      this.importantThing= result;
      console.log('my importantThing is', this.importantThing);
    });

只是把它扔出去作为一种选择。它非常有用的方式,我的应用程序的结构。该项目将保留在后台存储,直到您删除它。也可能有用,也可能没用。取决于你需要什么,我想!希望它有用。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54105700

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档