iPhone开发【三】处理基本交互
发布日期:2021-09-28 18:46:08 浏览次数:12 分类:技术文章

本文共 3901 字,大约阅读时间需要 13 分钟。

转载请注明出处,原文网址: 作者:张燕广

过了个中秋+国庆大长假,回来很累,又很忙,新产品iPhone客户端紧急开发中,挤点时间,继续写吧,GO!

实现的功能:1)点击button,将TextField中的内容更新到label中 2)TextField中内容发生变化后自动更新到label中

关键词:交互 事件处理 输出口 操作 关闭键盘 IBOutlet IBAction

1、创建一个Single View Application工程,命名为:BasicInteractive,如下图

BasicInteractive工程目录结构如下:

2、根据需求(即要实现的功能),整个场景中有3个组件:UILable、UITextField、UIButton,首先应该定义这些组件对应的变量,修改ViewController.h,修改后如下:

[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">#import <UIKit/UIKit.h>  
  2.   
  3. @interface ViewController : UIViewController  
  4. //添加如下代码  
  5. @property(nonatomic,retain)IBOutlet UILabel *label; //label指向xib文件中的UILabel组件  
  6. @property(nonatomic,retain)IBOutlet UITextField *textField;//textField指向xib文件中的UITextField组件  
  7. -(IBAction)do:(id)sender;//方法do与xib文件中的UIButton的点击事件关联起来  
  8. @end</span>  
1)声明变量为什么要加IBOutlet?什么意思?

     IBOutlet未执行任何操作,它仅仅是个标记,其唯一的作用是标示该实例变量(label、textField)将被连接到xib中UI控件。

     这里引出了一个新概念:输出口,这里label和textField被称为输出口,因为它们是用关键字IBOutlet声明的。

2)为什么没有声明Button的输出口?

      之所以声明输出口label、textField,是因为要访问UITextField获取其最新内容,要访问UILable为其设置最新内容,但是我们并不需要直接访问Button。

3)  方法do的返回类型为什么是IBAction?

      声明返回类型是IBAction,与声明void返回类型是相同的,这是声明操作方法不返回任何值的一种方法。

      这里的IBAction类似IBOutlet,也仅仅是一个标记,其唯一的作用是标示该方法是一个操作,且可以被某个控件触发。

      该方法接收一个参数,类型为id,为什么?参数sender指向触发do方法的那个控件,该控件是不确定的所以用id类型 。

      这里引出了一个新概念:操作,这里do方法被称为操作,因为它是用关键字IBAction声明的。   

3、编辑ViewController.xib,布局程序界面

1)点击ViewController.xib,打开该文件

2)拖动UILable UITextField UIButton 3个控件到view上,如下图

4、将输出口与UI控件相连,将触发事件的UI控件与操作相连

1)将输出口label与UILabel控件连接,按住label后面的圆圈拖向UILabel控件,如下图

2)按照上步操作将输出口textField与UITextField控件连接

3)将UIButton与操作do连接,如下图

选择事件Touch Up Inside

5、编辑ViewController.m

1)添加如下代码:

[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">@implementation ViewController  
  2. //添加的代码  
  3. @synthesize label;  
  4. @synthesize textField;</span>  
实现操作do,如下:
[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">-(IBAction)do:(id)sender{  
  2.     //将textField的内容设置给label  
  3.     label.text = textField.text;  
  4. }</span>  
修改方法- (void)viewDidUnload,如下:
[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">- (void)viewDidUnload  
  2. {  
  3.     [super viewDidUnload];  
  4.     label = nil;  
  5.     textField = nil;  
  6.     //创建工程时选择了arc,所以不能手动执行release  
  7.     //[label release];  
  8.     //[textField release];  
  9.     // Release any retained subviews of the main view.  
  10. }</span>  
6、至此,实现了功能1)点击button,将TextField中的内容更新到label中,编译、运行效果如下

7、要实现功能 2)TextField中内容发生变化后自动更新到label中,需要监听UITextField控件变化的事件,即当UITextField中内容发生变化时立即更新到UILable控件。

1)修改ViewController.h,添加操作

[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">-(IBAction)textFieldDidChange:(id)sender;//方法do与xib文件中的UITextField的Editting Changed事件关联起来</span><span style="font-family:Microsoft YaHei;font-size:18px;">  
  2. </span>  

2)参考上面UIButton控件与do操作的关联,将UITextField控件与textFieldDidChange操作进行关联,选择Editting Changed事件

3)修改ViewController.m,实现操作textFieldDidChange,如下所示

[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">//textField正在编辑  
  2. -(IBAction)textFieldDidChange:(id)sender{  
  3.     label.text = textField.text;  
  4. }</span>  
8、编译、运行,在TextField中输入内容时,UILabel会即时更新

1)但是,存在一个问题:输入完毕,点击键盘右下角的return或点击view上其它空白区域时,键盘不会消失(这个与Android键盘不同),需要我们编码实现。

2)修改ViewController.h,添加操作

[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">-(IBAction)textFieldDoneEndEditing:(id)sender;//方法textFieldDoneEndEditing与xib文件中的UITextField的Did End On Exit事件关联起来  
  2. -(IBAction)backgroudTap:(id)sender;//方法backgroudTap与xib文件中的view的Touch Down事件关联起来</span>  
3)参考上面UIButton控件与do操作的关联,将UITextField控件与textFieldDoneEndEditing操作进行关联,选择Did End On Exit事件

4)参考上面UIButton控件与do操作的关联,将view控件与backgroudTap操作进行关联,发现没有响应,

选中ViewController.xib,再选中View,如上图所示,将view的calss由UIView修改为UIControl,因为能够触发操作方法的所有控件必须继承自UIControl。再次操作,进行操作关联。

5)修改ViewController.m,实现操作textFieldDoneEndEditing、backgroudTap,如下

[cpp] 
  1. <span style="font-family:Microsoft YaHei;font-size:18px;">//textField编辑完毕  
  2. -(IBAction)textFieldDoneEndEditing:(id)sender{  
  3.     //textField放弃第一响应者  
  4.     [sender resignFirstResponder];  
  5. }  
  6.   
  7. //背景view被点击  
  8. -(IBAction)backgroudTap:(id)sender{  
  9.     [textField resignFirstResponder];  
  10. }</span>  
至此,已实现全部功能。

转载地址:https://blog.csdn.net/h3c4lenovo/article/details/8307228 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:iPhone开发【四】常用控件之ActionSheet与AlertView
下一篇:iPhone开发【二】重写HelloWorld(不使用XIB)

发表评论

最新留言

不错!
[***.144.177.141]2024年03月15日 13时36分33秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

android日期选择区间控件_Android时间区间的选择 2021-06-24
lin通讯从节点同步间隔场_LIN模块介绍 2021-06-24
mysql注入提取邮件_Mysql提取数据每日自动邮件通知 2021-06-24
mysql 列权限_mysql 权限相关 2021-06-24
手机端 vue+vant datetime支持时分秒_vueCli4+vant+router+vuex+移动端适配 2021-06-24
kafka消费者直接存在mysql中_【Canal】利用canal实现mysql实时增量备份并对接kafka 2021-06-24
python中readlines()函数_python中读取文件函数read()、readline()、readlines()的区别 2021-06-24
python入门之基础语法第四关输入输出答案_Python基本语法入门,基础 2021-06-24
mysql在存储过程仍_mysql存储过程 2021-06-24
失败的人生图片_早安励志经典语录精辟的一句话人生感悟 2021-06-24
如何设画面大小_如何设计旅游类项目?分享3种设计思路 2021-06-24
开启web_2021秋招四大网申时间、网申地址汇总(持续更新),德勤、安永、普华永道已开启!... 2021-06-24
从右边开始放_停路边,被人恶意放钉子,爆胎,报警无果,要我找监控 2021-06-24
读写测试_UFS 3.0读写测试数据曝光:秒杀UFS 2.1和eMMC 2021-06-24
注册小程序要多少钱_开发一个微信小程序商城要多少钱? 2021-06-24
mysql 实现id自增序列_MySQL分表自增ID解决方案 2021-06-24
反距离加权插值法例题_空间插值算法-反距离加权法 2019-04-21
oracle如何写循环日期自增_Oracle动态创建时间分区,以及Oracle12c中快速创建自增列... 2019-04-21
手机gps信息提取并储存到本地_通信人的实用技巧,如何在日常拍的照片里提取GPS位置信息... 2019-04-21
mysql5717开发设置怎么调回来_mysql 5.7.17 安装配置方法图文教程 2019-04-21