ionic入门教程第七课-简要说明几种界面之间的参数传递及优缺点

72 篇文章 0 订阅
20 篇文章 0 订阅

截至2016年4月13日19点32分,我发布的ionic入门教程,已经发布6课了,

总访问量将近6000,平均每节课能有1000的访问量。其中访客最多的是第三课有2700的访客。


其实我开始的时候计划的挺好的,就按照我这阶段的安排,慢慢的带大家做一个比较完整的项目。

但这几天发生了一些事情,让我不得不重新思考该跟大家说什么呢?

从访客数据来看,大家对于整体架构的布置和代码逻辑的规范相对比较感兴趣,也说明大家对基础入门的新建和普通的指令比较了解。

我本来是不打算讲过于基础的东西的,可是今天在技术群里,有个朋友问说ng-repeat怎么用?有人回答他连这个都问,那还怎么做项目。

其实我知道有些朋友基础比较差,看不懂API文档,或者对文档理解不是很清晰,但是人家想学啊。

我知道教这样的朋友并不需要什么技术,却需要足够的耐心。

而且今天我公司让我带一个零基础的同事学ionic,我打算在6-10天左右,让他上手做项目。

所以从下节课开始,我可能会更新比较基础简单的指令。

言归正传。

当项目慢慢做大,内容和业务越来越多的时候,我们都会涉及到多界面之间的参数传递。

再此我简要的说明一下几种比较常用的参数传递方式。

1、通过route传递

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Ionic中,可以通过以下几种方法实现页面之间的值传递: 1. 通过路由传参 在路由跳转时,可以通过queryParams或者state来传递参数,例如: 在源页面: ```typescript import { Router } from '@angular/router'; constructor(private router: Router) {} goToDestinationPage() { const params = { id: 123, name: 'John' }; this.router.navigate(['/destination'], { queryParams: params }); } ``` 在目标页面: ```typescript import { ActivatedRoute } from '@angular/router'; constructor(private route: ActivatedRoute) {} ngOnInit() { this.route.queryParams.subscribe(params => { console.log(params); // { id: '123', name: 'John' } }); } ``` 2. 通过Ionic的NavController传参 在跳转页面时,可以通过NavController的navigateForward和navigateRoot方法传递参数,例如: 在源页面: ```typescript import { NavController } from '@ionic/angular'; constructor(private navCtrl: NavController) {} goToDestinationPage() { const params = { id: 123, name: 'John' }; this.navCtrl.navigateForward('/destination', { queryParams: params }); } ``` 在目标页面: ```typescript import { NavController, NavParams } from '@ionic/angular'; constructor(private navCtrl: NavController, private navParams: NavParams) {} ngOnInit() { const params = this.navParams.get('queryParams'); console.log(params); // { id: 123, name: 'John' } } ``` 3. 通过localStorage或者sessionStorage存储值 在源页面: ```typescript localStorage.setItem('userId', '123'); ``` 在目标页面: ```typescript const userId = localStorage.getItem('userId'); console.log(userId); // '123' ``` 需要注意的是,这种方法可能会存在安全问题,因为存储在本地的数据可以被其他恶意网站或者插件访问和修改。 4. 通过Ionic的Events事件传递参数 在源页面: ```typescript import { Events } from '@ionic/angular'; constructor(private events: Events) {} goToDestinationPage() { const params = { id: 123, name: 'John' }; this.events.publish('destination:receivedParams', params); } ``` 在目标页面: ```typescript import { Events } from '@ionic/angular'; constructor(private events: Events) { events.subscribe('destination:receivedParams', (params) => { console.log(params); // { id: 123, name: 'John' } }); } ``` 需要注意的是,这种方法只适用于父子页面之间的值传递,如果需要在非父子关系的页面之间传递值,需要使用其他方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值