本话来介绍UIKit框架中的组件UITextField。

UItextField(文本框)和Label看起来看像,可是文本框是能够编辑的。在UI中使用文本框要注意。由于在模拟器上面输入文字是能够使用电脑键盘的。而在真机上。用户仅仅能使用虚拟键盘。所以要注意。另外文本框中的文字大小、颜色等等也是能够设置的,就和在Label中一样。

每次我们点击文本框開始输入内容的时候,文本框会成为页面上的first responder。这个时候虚拟键盘就会从底部滑出,配合我们的输入,就好像网页开发中的文本框获得了焦点一样。你能够用法becomeFirstResponder指定某个对象成为当前页面的first responder。假设要让键盘消失,我们仅仅须要让文本框又一次成为first responder,用法rsignFirstResponder。

在我们输入结束的时候,点击键盘上的Return键(当然。这个键显示的文字是能够编辑的)会触发代理的方法textFieldShouldReturn。通常你会在这种方法中写上sender.resignFirstResponder以关闭虚拟键盘。

当编辑结束后也就是上面说的textField又一次成为first responder时。会调用还有一个代理方法textFieldDidEndEditing。

UITextField也能够作为一个UI的控制器,就像button一样,我们能够通过button来触发target和action,也能够通过一个UITextField来触发一些action和target,仅仅只是触发的events和button是不同的。

以下来看一下键盘:

键盘出现是由于文本框向接口UITextInputTraits协议发送消息,这个协议是UITextField类遵循的。你能够使用协议中的属性来进行设置,比方Returnbutton显示的名称、密文输入等等。这些属性也能够在属性检查器中设置。

键盘滑出时可能会遮挡页面上的其它视图。我们须要让这些视图适应键盘的位置(尤其是文本框本身),为达到这个目的使用与键盘事件相关的NSNotification。之前我们已经接触过NSNotification了。如上例所看到的,在消息中心中接收这个NSNotification,然后在选择子相应的方法theKeyboardAppeared中捕获这个NSNotification然后从中提取userInfo中的信息进行相关处理。

以下是UITextField的一些其它属性,很的有趣

比方你能够设置在文字输入非常多的时候缩小字体以适应文本框的宽度。可是这个字体不能无限制缩小。假设adjustsFontSizeToFitSidth被设置为true,那么一定要设置minimumFontSize的尺寸。另外能够在文本框中能够增加一些辅助功能,比方说清空输入之类的。

【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记35 UITextField文本框的更多相关文章

  1. 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记1 IOS8概述

    首先感谢网易公开课和SwiftV课堂的朋友们辛苦翻译,这个系列是我学习斯坦福IOS8公开课的个人心得体会和笔记,希望能给大家带来启发. 首先我们要知道IOS系统中的结构情况,从贴近硬件的底层到贴近用户 ...

  2. 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记2 Xcode、Auto Layout及MVC

    原文链接不知道在哪, 接着上一话来讲,上一话中讲到了MVC,那么MVC在IOS8开发中是如何应用的呢?Paul Hegarty老师给我们展示了一个计算器的Demo,首先新建一个工程,老师把AppDel ...

  3. 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记19 为Demo添加手势

    在这一话中我们将应用上一话学到的知识来为Demo添加手势识别,首先添加一个缩放的功能,其次添加一个拖动功能,使得小人的表情可以随着我们的手指改变. 首先来添加一个缩放手势的识别器,我们来到FaceVi ...

  4. 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记30 ScrollView Demo实战

    在上一话中我们创建了一个通过URL读取图片的Demo,这个Demo是不能拖动和缩放的.如今给它添加选项让它能够手动切换URL,并把图片加入到ScrollView中. 向Storyboard中拖入一个s ...

  5. 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记3 Xcode、Auto Layout及MVC

    继续上一话中的计算器Demo.上一话讲到类必须被初始化.类中的属性也必须被初始化,所以你不能仅仅声明而不给它一个处置,那么问题来了,我们从storyboard中拖拽的@IBOutlet为什么仅仅有声明 ...

  6. 【我们都爱Paul Hegarty】斯坦福IOS8公开课个人笔记38 Unwind Segue反向过渡

    之前我们接触过了segue,这是IOS中最主要的传递方式,今天来解说一下怎样进行反向的segue. 反向过渡的使用前提是发出过渡的MVC必须是由目标MVC直接或者间接正向过渡来的.反向过渡是唯一不会创 ...

  7. 【我们都爱Paul Hegarty】斯坦福大学IOS8公开组个人笔记28 ScrollView 幻灯片视图

    随着移动设备,iphone屏幕尺寸的限制.超过内容的屏幕大小为scrollview于,通过滑动来获得.scrollview滑动方向可以是也可以是横向垂直,scrollview可以嵌套,例如,纵向滑动s ...

  8. 斯坦福iOS7公开课11笔记及演示Demo&访问HTTPS链接下载数据

    这一节主要介绍UITableView以及iPad,Demo为从Flicker下载图片并显示,但是实际过程中发现需要FQ并使用HTTPS连接,所以这次用了两个Demo,一个是课程中的Demo,另一个是简 ...

  9. 斯坦福iOS7公开课10笔记及演示Demo

    这一节主要介绍了多线程中的串行队列以及滚动视图UIScrollView. 1 .多线程 这一节只是简单介绍了多线程的串行队列,即把任务加入线程队列后按顺序逐步执行. (1)目前iOS多线程提供的方法主 ...

随机推荐

  1. vue项目,封装api并使用

    封装api index.js let uploadBase = '' if(process.env.NODE_ENV === 'production'){ uploadBase = 'https:// ...

  2. 搭建javawebxiangmu

    https://blog.csdn.net/qq_23994787/article/details/73612870#

  3. 多任务-进程之Queue的进程间通信

    1.经过线程和进程的对比,不难的知道,线程和进程有相当大的区别,如全局变量资源不能够共享. 2.在不同的进程间,如何实现通信呢? 需要提及的一个概念就是Queue,它是一个消息队列,下面通过一个例子来 ...

  4. 推断扫描后的内容是否是URL

    扫描的明明是Url.竟然当文本给处理了,看来正则没有通过. 扫描二维码后,我參考了QQ的效果.分了三种:网页地址.文件下载地址,文本信息:为了实现这样的效果.我 发现有非常多url非常奇葩.所以就想找 ...

  5. hdu3468 Treasure Hunting 二分匹配

    //给一个n*m的图 //.表示空白地 //*表示有黄金 //#表示墙 //一个人须要依照A...Z..a..z的顺序以最短路径走到下一个 //每次仅仅能在他的路线上经过的地方取一块黄金 //问最多能 ...

  6. HDU 4288-Coder(模拟)

    Coder Time Limit: 20000/10000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  7. sage开发url替换字符串

    /// <summary>         /// Url字段值替换,无该字段则加入         /// </summary>         /// <param ...

  8. How to Download Windows 10 Spotlight/Lock Screen Images

    http://www.online-tech-tips.com/windows-10/download-windows-10-spotlight-lock-screen-images/ 图片位置 C: ...

  9. matplotlib 可视化 —— 定制 matplotlib

    1. matplotlibrc 文件 matplotlib使用matplotlibrc [matplotlib resource configurations] 配置文件来自定义各种属性,我们称之为 ...

  10. [HNOI2012] 永无乡 解题报告 (splay+启发式合并)

    题目链接:https://www.luogu.org/problemnew/show/P3224#sub 题目: 题目大意: 维护多个联通块,没有删除操作,每次询问某一联通块的第k大 解法: 维护联通 ...