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. vsftpd.conf 详解

    //不允许匿名访问 anonymous_enable=NO //设定本地用户可以访问.注意:主要是为虚拟宿主用户,如果该项目设定为NO那么所有虚拟用户将无法访问 local_enable=YES // ...

  2. angular项目文件概览

    在Mac上打开终端,输入ng new b-app  如下: 然后在webstorm中打开 src文件夹 你的应用代码位于src文件夹中. 所有的Angular组件.模板.样式.图片以及你的应用所需的任 ...

  3. JVM内存分配及GC简述

    在阐述JVM的内存区域之前,先来看下计算机的存储单位.从小到大依次为Bit,Byte,KB,MB,GB,TB.相邻的单位相差2的10次方. 计算机运行中的存储元件主要分为寄存器(位于CPU)和内存,寄 ...

  4. MySQL JDBC驱动下载

    下载地址:https://pan.baidu.com/s/1VLNaV_rz2P1jMtYrjJydiQ

  5. css3 图标变大变小在变小变大

    css3 @-webkit-keyframes anLoca { from { -webkit-transform: scale3d(1, 1, 1); } to { -webkit-transfor ...

  6. 【58沈剑架构系列】细聊分布式ID生成方法

    一.需求缘起 几乎所有的业务系统,都有生成一个记录标识的需求,例如: (1)消息标识:message-id (2)订单标识:order-id (3)帖子标识:tiezi-id 这个记录标识往往就是数据 ...

  7. SGU 208. Toral Tickets

    208. Toral Tickets time limit per test: 0.25 sec. memory limit per test: 65536 KB input: standard ou ...

  8. python collection系列

    collection系列 不常用功能,需要进行模块功能导入: import collection Counter 常用方法测试: #!/usr/local/env python3 ''' Author ...

  9. jquery通配符说明

    按姓名匹配 1,name前缀为aa的所有div的jquery对象 Js代码 收藏代码$("div[name^='aa']"); 2,name后缀为aa的所有div的jquery对象 ...

  10. jquery放大镜非常漂亮噢

    这个放大镜的代码挺简单滴效果也不错. <script> //QQ:496928838 微凉 $(function(){ $("#demo").enlarge( { // ...