使用Delegate实现不同页面间的传值

简介:
复制代码
两个View之间的传值可以有多种方式。但本人觉得最合理最自然并且最安全的方式是通过Delegate方式。

设想一个场景:

1. 有两个View,分别是A和B。

2. 点击A中的某个按钮,出来B。

3. 对B做某些操作(比如输入文字到textField,选择picker等等)。

4. 然后点击B中的确定按钮,将在B中进行的操作所产生的数据传递给A。

这种应用场景在编写iPhone App应用的时候是十分常见的,比如利用modelview来进行某些条件的选择,进行注册操作等等。下面具体说说利用Delegate是如何将View B中的数据传递回View A。

第一步:

在B类的类定义之前加入一下代码,定义一个delegate:

[plain] view plaincopy

@protocol ViewBControllerDelegate <NSObject>
- (void) viewAWillDoThisAction:(UIViewController *) currentView;
@end

这个delegate定义了一个方法,所有实现了这个delegate的类都必须实现这个方法。

然后再在B类的类定义中添加一个member,加入以下代码:

[plain] view plaincopy

NSObject<FilterSpotsViewControllerDelegate> *view_A;

从名字来看,就知道待会这个值会被赋予View A。

第二步:

让A类实现ViewBControllerDelegate:

[plain] view plaincopy

@interface ViewAController : UIViewController <ViewBControllerDelegate>

并且让A类实现方法viewAWillDoThisAction:

[plain] view plaincopy

- (void) viewAWillDoThisAction:(UIViewController *) view_B {
//利用view_B来传值。如self.a = view_B.a;
}


上面代码中,将会在B类中将B类自己(self)的指针传递给view_B(见下面第四步)。这样就可以把B类的数据传递给A类了。

第三步:

就如我之前所说的,View A点某个按钮之后,出现View B。假设这个按钮对应的方法是“-(void) pushViewB: (id) sender"。那么应在这个方法中将A类自身的指针(self)传递给之前第一步在B类中定义的成员变量View_A:

[plain] view plaincopy

-(void) pushViewB: (id) sender {
//初始化一个B类,view_B
view_B.view_A = self; //赋值
//推出View B
}


第四步:

在B类,假设在View B中做完所有操作之后,点击确定按钮,返回View A,并将数据传回给view A。假设这个确定按钮的方法是-(void)done: (id) sender。那么需要在这个方法中调用A类实现的viewAWillDoThisAction:

[plain] view plaincopy

-(void) done: (id) sender {
[self.view_A viewAWillDoThisAction:self];
//返回View A
}


上面代码注意两个问题:第一是调用view A的实现了delegate的方法,第二是将自身的指针传递给view A的方法,以方便view A能取到view B的数据。

以上就是整个利用delegate机制来进行两个view之间的传值的过程。这里注意一点:这两个view之间是有关系的(view A推出view B,从view B推出view A)。对于两个完全没有关系的view,如何传值呢?理论上利用delegate也是可以的,但并不是最好的方法。最好的方法是利用NSNotification,留到日后再说。

多嘴一点,其实说是利用delegate的方式来传值,其本质是传递类的指针来进行类成员的传值(实现了delegate的类A将自身传给了类B,然后类B又将自身传回去给类A),之所以用到delegate的机制,只不过是为了说明这个顺序:当B进行了某个操作的时候,需要A去做另外一件事。这就是delegate的本质。也就是我文章开头所说“最合理最自然”的原因。
复制代码


编辑器加载中...

本文转自编程小翁博客园博客,原文链接:http://www.cnblogs.com/wengzilin/archive/2012/03/14/2396170.html,如需转载请自行联系原作者

相关文章
【Layui】子页面向父级页面传递参数
【Layui】子页面向父级页面传递参数
1110 0
【Layui】子页面向父级页面传递参数
|
8月前
|
JavaScript
Vue父组件调用子组件的方法并传参的两种方式(用$refs.refName.functionName、window.function)
Vue父组件调用子组件的方法并传参的两种方式(用$refs.refName.functionName、window.function)
Vue父组件调用子组件的方法并传参的两种方式(用$refs.refName.functionName、window.function)
|
JavaScript 前端开发
js事件绑定的几种方法?
js事件绑定的几种方法?
|
8月前
|
JavaScript
Vue子组件调用父组件方法并传参的5种方式:$emit触发、传入子组件function、访问父组件$parent.function、用inject关联父组件provide的方法、用window.fun
Vue子组件调用父组件方法并传参的5种方式:$emit触发、传入子组件function、访问父组件$parent.function、用inject关联父组件provide的方法、用window.fun
|
小程序 JavaScript
小程序点击事件传参
小程序点击事件传参
326 0
|
前端开发
React 跳转页面 传递传递参数,并获取参数
React 跳转页面 传递传递参数,并获取参数
215 0
|
JavaScript
解决 Element-ui中 对话框 (Dialog)中含子组件时,使用 refs 调用该子组件为 undefined 的问题
解决 Element-ui中 对话框 (Dialog)中含子组件时,使用 refs 调用该子组件为 undefined 的问题
780 0
解决 Element-ui中 对话框 (Dialog)中含子组件时,使用 refs 调用该子组件为 undefined 的问题
使用NavHostFragment、navigation--- avtivity向fragment传值,fragment之间传值
使用NavHostFragment、navigation--- avtivity向fragment传值,fragment之间传值
265 0