iOS - UIKit 框架常用API

1、UIView

  • 设置大小、位置 frame
  • 使用栈的方式管理子view:addSubView,当子view在位置上有重叠,则优先显示栈顶view
  • 主要的生命周期
    init
    willMoveToSuperview
    didMoveToSuperview
    willMoveToWindow
    didMoveToWindow

2、UIViewController

  • 管理 view 层级
  • 自带一个默认 view,是所有子view的容器
  • 主要的生命周期
    init
    viewDidLoad
    viewWillAppear
    viewDidAppear
    viewWillDisappear
    viewDidDisappear
    Dealloc

3、UIWindow

1、iPhone应用程序通常只有一个窗口,表示为一个UIWindow类的实例
2、窗口显示出来之后,您很少需要再次引用它

UIWindow* aWindow = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];

4、UIApplication

1、UIApplication类提供了对运行在IOS设备上的app集中控制和调度的机制;
2、每一个IOS app必须有一个而且只能有一个UIApplication或者其子类的实例;
3、当程序启动的时候,会调用UIApplicationMain函数,创建UIapplication单例,该单例在整个IOS系统中就是你的App的抽象
4、能够通过shareApplication方法来调用该单例
5、UIApplication还维护了当前App打开的窗口的列表。所以,你通过它能够取到你App中任何一个View
6、app实例还实现了一个delegate,接受各种各样程序运行时的事件,比如:程序启动、低内存警告、程序崩溃等等
7、能通过openURL:方法来接受和处理一个邮件或者图片文件。如一个以Email开头的URL将能够唤起Email程序来展示这个邮件
8、注册远程消息通知,执行程序级别的复位操作

5、UINavigationController

  • 通过栈管理单页面交互,如从主页进入详情页
  • 通常仅展示栈顶 Controller
  • Push/Pop 操作


6、UITabBarController

管理多个 UIViewController 的切换,通过点击底部UITabBar中的TabBar来展示对应的 UIViewController


UITabBarController.png

使用方式:

1、调用 setViewControllers 方法设置 ViewController
2、设置每个 ViewController 的 tabBarItem 的 title/image


UITabBarController

7、UITableView 和 UITableViewCell


8、UICollectionView




9、UIScrollView


10、基础控件

  • UILabel



  • UIImage



  • UIButton



    UIButton 继承自 UIControl ,拥有了点击等交互能力,对于一般的 View,并没有继承UIControl,要实现交互需要使用 UIGestureRecognizer

  • UIGestureRecognizer


  • UIAlertView
    该组件已被废弃,但可以从中学习组件的设计


  • WKWebview
    注:该组件并不属于 UIKit ,而是在单独的 WebKit 库里



11、动画



11、常见两种布局


12、常见模式

  • MVC
    UITabBarController: C
    tabBarItem: V
    tabBarItem.title/image: M
  • Delegate
    一对一模式


  • Target-Action


  • KVO
    一对多,类似观察者模式


参考

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 227,837评论 6 531
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 98,196评论 3 414
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 175,688评论 0 373
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 62,654评论 1 309
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 71,456评论 6 406
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 54,955评论 1 321
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 43,044评论 3 440
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 42,195评论 0 287
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 48,725评论 1 333
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 40,608评论 3 354
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 42,802评论 1 369
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 38,318评论 5 358
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 44,048评论 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 34,422评论 0 26
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 35,673评论 1 281
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 51,424评论 3 390
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 47,762评论 2 372

推荐阅读更多精彩内容