StoryBoard学习(5):使用segue页面间传递数据

函数:

  1. - (void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender

具体例子:

1.首先创建1个Single View模版项目,然后在MainStoryboard中添加1个新的ViewContronller。并在2个View Controller中添加标签、按钮、编辑输入框。

2. 将第1页和第2页建立segue。

选中第1页中的按钮[跳到第2页],鼠标右键(或按住Controll键,鼠标左键)拖拽到第2页后,放手,在弹出菜单上选择[modal]

3. 将第1页中的编辑输入框组件与class文件挂钩。

单独窗口打开MainStoryboard和ViewController.h文件,然后鼠标右键拖拽编辑输入框到.h文件中的@interface的下一行。

注意,编辑输入框组件的name属性这里设置为 page1Data

4.在ViewController.m中添加如下代码。

在@implementation之后添加:

  1. @synthesize page1Data;

重载prepareForSegue方法:

  1. -(void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender{
  2. NSString* data = page1Data.text;
  3. UIViewController* view = segue.destinationViewController;
  4. if ([view respondsToSelector:@selector(setParam:)]) {
  5. [view setValue:data forKey:@"param"];
  6. }
  7. }

注意:其中的setParam和param会和下面的代码进行关联!!

5.添加新类文件并绑定给第2页。

注意:Class名为 SecondViewController

将类SecondViewController绑定到第2页.

6.将第2页中的编辑输入框组件绑定到类SecondViewController中。

单独窗口打开SecondViewController.h和MainStoryboard,然后选中第2页中的编辑输入框,然后鼠标右键拖拽编辑输入框到SecondViewController.h文件中的@interface的下一行。

注意:绑定时编辑输入框组件的name属性设置为 page2Data。

7.修改SecondViewController的.h和.m文件。

7.1 修改SecondViewController.h

@interface SecondViewController : UIViewController之后添加:

  1. @property (strong, nonatomic) NSString *param;

注意:这里定义的参数 param 必须和前面ViewController.m中的prepareForSegue方法中的param相同!!!

7.2 修改SecondViewController.m

在@implementation SecondViewController之后添加:

  1. @synthesize param;
  2. @synthesize page2Data;

修改方法viewDidLoad:

  1. - (void)viewDidLoad
  2. {
  3. [super viewDidLoad];
  4. // Do any additional setup after loading the view.
  5. page2Data.text=param;
  6. }

编译运行,当在第1页中输入参数,跳到第2页后可以显示第1页中输入的参数。

8. 给第2页中的按钮[关闭窗口]添加事件。

单独窗口打开SecondViewController.h和MainStoryboard,然后选中第2页中的按钮[关闭窗口],右键拖拽到SecondViewController.h中@interface SecondViewController : UIViewController之后;

在弹出窗口的Connection属性选择Action,Name属性设置为closeWin。然后点按钮[Connect]。

可以看到,在SecondViewController.h中增加了如下代码:

  1. - (IBAction)closeWin:(id)sender;

在SecondViewController.m中增加了如下代码:

  1. - (IBAction)closeWin:(id)sender {
  2. }

修改 SecondViewController.m中的closeWin方法,具体代码如下:

  1. - (IBAction)closeWin:(id)sender {
  2. [self dismissViewControllerAnimated:YES completion:nil];
  3. }

编译运行,当显示第2页后,点击[关闭窗口]按钮,即可关闭第2页,重新显示第1页。

接下来,要实现在第2页修改接收到的参数,然后将修改后的参数返回给第1页。

9. 修改 ViewController.h和.m文件内容。

9.1 ViewController.h

在 @interface ViewController : UIViewController 之后添加:

  1. @property (strong,nonatomic) NSString* editData;

注意:定义的变量 editData 是用来接收 第2页编辑输入框的内容,在 SecondViewController.m会用到!!!

9.2 ViewController.m

在 @implementation ViewController 之后添加:

  1. @synthesize editData;

修改方法 -(void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender

  1. -(void)prepareForSegue:(UIStoryboardSegue *)segue sender:(id)sender{
  2. NSString* data = page1Data.text;
  3. UIViewController* view = segue.destinationViewController;
  4. if ([view respondsToSelector:@selector(setParam:)]) {
  5. [view setValue:data forKey:@"param"];
  6. }
  7. if ([view respondsToSelector:@selector(setFirstViewController:)]) {
  8. [view setValue:self forKey:@"firstViewController"];
  9. }
  10. }

注意:其中的 setFirstViewController 和 firstViewController 在下面的 SecondViewController.h和.m中会定义!!!

重载方法 -(void)viewWillAppear:(BOOL)animated :

  1. -(void)viewWillAppear:(BOOL)animated{
  2. NSLog(@"viewWillAppear");
  3. [super viewWillAppear:animated];
  4. page1Data.text=editData;
  5. }

10. 修改 SecondViewController.h和.m文件内容。

10.1 SecondViewController.h

在 @interface SecondViewController : UIViewController 之后添加:

  1. @property (strong,nonatomic) id firstViewController;

注意:变量名称 firstViewController必须和上面ViewController.m中相同!!!

10.2 SecondViewController.m

在  @implementation SecondViewController 之后添加:

  1. @synthesize firstViewController;

重载方法 -(void)viewWillDisappear:(BOOL)animated

  1. -(void)viewWillDisappear:(BOOL)animated{
  2. [super viewWillDisappear:animated];
  3. if ([firstViewController respondsToSelector:@selector(setEditData:)]) {
  4. [page2Data endEditing:YES];
  5. [firstViewController setValue:page2Data.text forKey:@"editData"];
  6. }
  7. }

注意:其中的  setEditData 和  editData 必须和上面 ViewController.h和.m中定义的相同!!!

OK,编译运行。第1页的输入文字会传递到第2页的输入框中,第2页的输入框文字在关闭窗口后同样会传递给第1页的输入框中。

原文:http://stephen830.iteye.com/blog/1696614

StoryBoard学习(5):使用segue页面间传递数据的更多相关文章

  1. 在微信小程序页面间传递数据总结

    在微信小程序页面间传递数据 原文链接:https://www.jianshu.com/p/dae1bac5fc75 在开发微信小程序过程之中,遇到这么一些需要在微信小程序页面之间进行数据的传递的情况, ...

  2. 对于vue和react“页面间”传递数据的理解误区

    前言 如果我们想要实现多个标签页之间的通信,可以使用localStorage.cookie等,但是能不能用vue或react呢? 结论 答案是NO,因为vue和react虽然可以在“多个”页面之间传递 ...

  3. 开发 | 如何在微信小程序的页面间传递数据?

    我们在之前发布过小程序页面传值方法的简单介绍,说明了在小程序开发中,两种常见的页面之间传值方法. 本期,知晓程序(微信号 zxcx0101)为你带来的是「倒数记日」小程序开发者带来的,小程序开发中,有 ...

  4. Windows Phone 几种页面间传递数据的方式

    首先,我们要引用:using Microsoft.Phone.Shell; 第一种: // 导航到新页面 NavigationService.Navigate(new Uri("/Detai ...

  5. react-native页面间传递数据的几种方式

    1. 利用react-native 事件DeviceEventEmitter 监听广播 应用场景: - 表单提交页面, A页面跳转到B页面选人, 然后返回A页面, 需要将B页面选择的数据传回A页面. ...

  6. php 页面间传递数据

    b.php <?php function getClientIP() { if (getenv("HTTP_CLIENT_IP")) $ip = getenv("H ...

  7. 小菜学习Winform(五)窗体间传递数据

    前言 做项目的时候,winfrom因为没有B/S的缓存机制,窗体间传递数据没有B/S页面传递数据那么方便,今天我们就说下winfrom中窗体传值的几种方式. 共有字段传递 共有字段传递实现起来很方便, ...

  8. ios页面间传递参数四种方式

    ios页面间传递参数四种方式 1.使用SharedApplication,定义一个变量来传递. 2.使用文件,或者NSUserdefault来传递 3.通过一个单例的class来传递 4.通过Dele ...

  9. Java WEB 之页面间传递特殊字符

    本文是学习网络上的文章时的总结以及自己的一点实践.感谢大家无私的分享. 昨天在做项目的时候,有一个页面间传递特殊字符的需求,查了一些资料.如今将自己的经验写出来. 首先.在前台编码 var fckPu ...

随机推荐

  1. 【转载】如何解决failed to push some refs to git

    在使用git 对源代码进行push到gitHub时可能会出错,信息如下   此时很多人会尝试下面的命令把当前分支代码上传到master分支上. $ git push -u origin master ...

  2. The algorithm of entropy realization

    近似熵的一种快速实用算法 Pincus提出的近似熵算法中有很多冗余的计算,效率低,速度慢,不利于实际应用,洪波等人在定义的基础上引入二值距离矩阵的概率,提出了一种实用快速的算法. function A ...

  3. UIScrollViewDelegate 方法调用

    UIScrollViewDelegate 方法调用 /** 设置缩放的View, 初始化完之后调用此方法告诉scrollView 谁可以缩放操作, 然后进行布局 */ func viewForZoom ...

  4. [转载]锁无关的(Lock-Free)数据结构

    锁无关的(Lock-Free)数据结构 在避免死锁的同时确保线程继续 Andrei Alexandrescu 刘未鹏 译 Andrei Alexandrescu是华盛顿大学计算机科学系的在读研究生,也 ...

  5. 使用xbee连接地面站和飞控

    Zigbee是一种短距离.低功耗的近距离无线组网通讯技术,主要适用于自动控制和远程控制领域,可以嵌入各种设备. DIGI的ZigBee产品XBee小型但却是一个功能完善的ZigBee收发器(即接收器/ ...

  6. java基础15 内部类(成员内部类、局部内部类)和匿名内部类

    一.内部类 1.1.1.成员内部类 一个类定义在另一个类的内部,那么该类就叫作成员内部类 1.1.2.成员内部类访问方式 方式一:在外部类中提供一个方法创建内部类的对象进行访问       方式二:在 ...

  7. Python+Selenium 自动化实现实例-数据驱动实例

    #coding=utf-8 from selenium import webdriver driver = webdriver.Firefox() driver.implicitly_wait(10) ...

  8. fedora安装后的配置

    fedora安装后的一些配置 (mirror)源 换源 默认从fedora官网下载太慢,考虑换用国内的源(镜像站点),推荐中科大.阿里云.浙大.网易等的源. 比如我用浙大ZJU的源http://mir ...

  9. [你必须知道的.NET]第二十二回:字符串驻留(上)---带着问题思考

    发布日期:2008.8.27 作者:Anytao © 2008 Anytao.com ,Anytao原创作品,转贴请注明作者和出处. 说在,开篇之前 走钢丝的人,在刺激中体验快感.带着问题思考,在问题 ...

  10. NIO-3网络通信(非阻塞)

    import java.io.IOException; import java.net.InetSocketAddress; import java.nio.ByteBuffer; import ja ...