iOS知识点总结(一)

iOS需要学习的内容

UI

  • 基础控件: UIButton、UIImageView、UILable、UIView、UISlider等
  • 高级控件: UITableView、UICollectionView等
  • 屏幕适配: Autoresizing、Autolayout、Sizeclass、Masonry
  • 多控制器管理: UINavigationController、UITabBarController、自定义控制器管理
  • Quartz2D、核心动画、事件处理、手势、UIDynamic

多线程网络

  • NSThread、NSoperation、GCD
  • Socket、TCP/IP
  • 网络安全、加密算法、HTTPS
  • NSURLConnection、NSURLSession、UIWebView
  • AFNetWorking、SDWebImage、MJRefresh、MJExtension

HTML5

  • HTML、CSS、JavaScript
  • 响应式布局、BootStrap、jQuery、jQuery-Mobile
  • HTML5 + Native混合开发

实用技术

  • plist存储、NSCoding、SQLite、CoreData
  • 音频、视频、流媒体、滤镜处理、拍照、相册、讯飞语音
  • 推送、加速计、单元测试、静态库、第三方登录
  • App Extensions、炫酷动画特效、地图定位
  • 二维码、正则表达式、打包发布程序
  • 瀑布流、自定义UICollecitonViewLayout
  • svn、git、github、CocoaPods
  • 社交分享、应用统计、硬件信息获取(内存、CPU等)
  • 第三方支付、内购、通讯录

UIView的常见是属性

  • 获得自己的父控件对象
@property(nonatomic,readOnly) UIView *superView;
  • 获得自己的所有子对象
@property(nonatomic,readOnly,copy) NSArray *subviews;
  • 控件的标识父控件可以通过tag来找到对应的子控件
@property(nonatomic)NSInteger tag
  • 控件的形变属性,可设置旋转角度,比例缩放,平移等属性
@property(nonatomic)CGAffineTransform transform
  • 添加一个子控件view
 - (void)addSubview: (UIView *)view;
  • 从父控件中移除
 - (void)removeFromSuperView;
  • 根据一个tag标识找出对应的控件(一般都是子控件)
 - (UIView *)viewWithTag:(NSInteger)tag;
  • 控件矩形框在父控件中的位置和尺寸(以父控件左上角为坐标原点)
@property(nonatomic) CGRect frame;
  • 控件矩形框的位置和尺寸(以自己的左上角为坐标原点,所以bounds的x/y一般为0)
@property(nonatomic) CGRect bounds;
  • 控件中心点的位置(以父控件左上角为坐标原点)
@property(nonatomic) CGPoint center;

UI控件概览

  • UIButton 按钮 ----监听用户的点击,在用户点击后做出响应
  • UILabel 文本标签 ----显示一串固定的文字
  • UITextField 文本输入框 ----可以弹出键盘,让用户输入文本内容
  • UIImageView 图片显示
  • UIScrollView 滚动的控件----如果内容较多,超出了一个屏幕的宽度,就用它来显示
  • UITableView 表格----如果每一行显示的内容格式差不多,就用这个表格控件
  • UICollectionView 九宫格----显示的东西是一格一格的,就用这个
  • UIWebView 网页显示控件----使用它就可以在手机上浏览网页
  • UIAlertView 中间弹框----从屏幕中间弹出一个框,提示用户下一步怎么做
  • UINavigationBar 导航条----显示在顶部的条
  • UIPageControl 分页控制----能显示当前的页码
  • UITextView 能滚动的文字显示控件----文字较多,可以换行,可以编辑
  • UIActivityIndicator 圈圈----表示让用户等待
  • UISwitch 开关
  • UIActionSheet 底部弹框----从屏幕底部弹出一个框,提示用户
  • UIDatePicker 日期选择器
  • UIToolBar 工具条----一般显示在底部或者键盘顶部,里面有几个小按钮
  • UIProgressView 进度条----水平进度条,如显示下载进度,程序启动进度
  • UISlider 滑块----在两个竖直之间滑动选择,如音量/亮度选择
  • UISegmentControl 选项卡----在几个固定选项中进行选择
  • UIPickerView 选择器----在多行数据中选择一行

什么是UIImageView

  • UIKit框架提供了很多UI控件,有的不常用,有的非常常用,如:UIButton/UILabel/UIImageView/UITableView等
  • UIImageView极其常用,功能比较单一:显示图片

什么是UILabel

  • UILabel极其常用,功能比较单一:显示文字

什么是按钮

  • 一般情况下,点击某个控件后,会做出相应反应的都是按钮
  • 按钮的功能比较多,既能显示文字,也能显示图片,还能随时调整内部文字和图片的位置

按钮的设置

UIButton的状态

  • normal 普通状态,对应的枚举常量:UIControlStateNormal
  • highlighted 高亮状态,对应的枚举常量:UIControlStateHighlighted
  • disabled 失效状态,对应的枚举常量:UIControlStateDisabled

设置按钮的背景图片

  • 设置按钮在不同状态下的背景图片(为保证高亮状态下的图片正常显示,按钮的style必须为custom)

按钮的样式

  • 实际上按钮自带了很多不同的样式
  • 在用代码创建按钮时同时指定按钮的样式
UIButton *btn = [UIButton buttonWithType: UIButtonTypeCustom];
UIButtonTypeCustom:无类型,按钮的内容需要自定义
UIButtonTypeDetailDiscloure
UIButtonTypeInfoLight
UIButtonTypeInfoDark
UIButtonTypeContactAdd

UIButton的常见设置

  • 设置按钮的文字
 -(void)setTitle:(NSString *)title forState:(UIControlState *)state;
  • 设置按钮文字的颜色
 -(void)setTitleColor:(UIColor *)color forState:(UIControlState *)state;
  • 设置按钮内部的小图片
 -(void)setImage:(UIImage *)image forState:(UIControlState *)state;
  • 设置按钮的背景颜色
 -(void)setBackgroundImage:(UIImage *)image forState:(UIControlState *)state;
  • 设置按钮的文字字体
 btn.titleLabel.font = [UIFont  systemFontOfSize:13];
  • 获得按钮的文字
 -(NSString *)titleForState:(UIControlState)state;
  • 获得按钮的文字颜色
 -(UIColor *)titleColorForState:(UIControlState)state;
  • 获得按钮的内部小图片
 -(UIImage *)imageForState:(UIControlState)state;
  • 获得按钮的背景图片
 -(UIImage *)backgroundImageForState:(UIControlState)state;

代码创建按钮

UIButton *btn = [UIButton buttonWithType:UIButtonTypeCustom]
[btn setBackgroundImage:[UIImage imageNamed:"btn_01"] forState:UIControlStateNormal]
[btn setTitle:"点我啊" forState:UIControlStateNormal]
[btn setTitleColor:[UIColor redColor] forState:UIControlStateNormal]

九宫格计算思路

plist文件

  • 什么是plist文件

  • 直接将数据写在代码里面,不是一种合理的做法,如果数据经常改动,代码也就需要经常改动,造成代码的扩展性低;

  • 因此,可以考虑将经常变动的数据放在文件中存储,程序启动后从文件中读取最新的数据,如果数据要变,只需要修改文件,不需要修改代码;

  • 一般可以使用属性列表文件存储NSArray和NSDictionary之类的数据,这种"属性列表文件"的扩展名是plist,因此称之为plist文件

  • 创建plist文件

  • 解析plist文件

1.获得plist文件的全路径
 NSString *path = [[NSBundle MainBundle] pathForResource:@"shops" ofType:@"plist"]
 2.加载plist文件
 self.shops = [NSArray arrayWithContentOfFile:path];
  • plist文件名不能叫做"info""Info"

用模型取代字典的好处

  • 使用字典的坏处:一般情况下,设置数据和取出数据都要使用"字符串类型key",编写这些key时,编译器没有自动提示,如果写错了也不会有任何的报警和错误
  • 使用模型的好处:
    1.所谓模型,其实就是数据模型,专门用来存放数据的对象,用它来表示数据会更加专业
    2.模型设置数据和取出数据都是通过它的属性,编译器可以监测是否正确
    3.使用模型访问属性时,编译器会有智能提示,提高代码书写效率
  • 字典转模型
  • 字典转模型的过程最好封装在模型内部
  • 模型应该提供一个可以传入字典参数的构造方法
 -(instancetype)initWithDict(NSDictionary *)dict;
 +(instancetype)xxxWithDict(NSDcitionary *)dict;
  • instancetype
    1.instancetype在类型上表示上,跟id一样,可以表示任何对象类型
    2.instancetype只能用在返回值上,不能像id一样用在参数类型上
    3.instancetype比id多一个好处,编译器会监测instancetype的真实类型

view的封装

  • 如果一个view的内部子控件比较多,一般会考虑自定义一个view,把它内部的子控件的创建封装起来,不让外界关心
  • 外界可以传入对应的模型给view,view拿到模型后将数据展示到响应的子控件身上
  • 封装控件的基本步骤
    1.在initWithFrame:方法中添加子控件,提供便利构造方法
    2.在layoutSubviews方法中设置自控件的frame,一定要调用父类layoutSubviews
    3.增加模型属性,在模型属性的set方法中设置数据到子控件上

简单的MVC

  • controller 控制器/大管家
  • view 视图显示
  • model 数据模型/数据

xib和storyboard的对比

  • 共同点
    1.都是用来描述软件界面
    2.都用Interface builder工具来编辑
    3.本质都是转为代码去创建控件
  • 不同点
    1.xib是轻量级的,用来描述局部UI界面
    2.storyboard是重量级的,用来描述整个UI界面,并能描述多个界面之间的跳转关系

xib的加载

  • 方法一
NSArray *views = [[NSBundle MainBundle] loadNibNamed:@"xib name" owner:nil, options: nil]
  • 方法二
UINib *nib = [UINib nibWithNibName:@"" bundle: nil]
NSArray *view = [nib instantiateWithOwner:nil options: nil]

使用xib自定义view

  • 新建自定义控件类
  • 新建xib文件,建议文件名与view的类名一致
  • 修改xib中view的类名
  • 封装xib的加载过程
+ (instancetype)shopView
{
    return [[[NSBundle MainBundle] loadNibNamed:@"" owner:nil options: nil] lastObject];
}
  • 增加模型属性,在模型属性的set方法中设置数据到子控件中
  • 注意点
  • 一个控件有两种创建方式
    • 通过代码创建:初始化时一定会调用initWithFrame:方法
  • 通过xib/storyboard创建
    • 初始化时不会调用initWithFrame:方法,之后调用initWithCoder:方法
    • 初始化完毕后会调用awakeFromNib方法
  • 有时候希望在控件初始化的时候做一些初始化操作,比如添加子控件,设置基本属性
    • 这时候需要根据控件的常见方式来选择在哪个方法中操作

UIImage

UIImage *image = [UIImage imageNamed:@""];

UILabel

  • UILable的基本设置
  - @property(nonatomic,copy) NSString *text;
  - @property(nonatomic,retain) UIFont *font;
  - @property(nonatomic,retain) UIColor *textColor;
  - @property(nonaotomic) NSTextAlignMent textAlignMent;

UIFont

+(UIFont *)systemFontOfSize:(CGFloat)fontSize;//系统默认字体
+(UIFont *)boldSystemFontOfSize:(CGFloat)fontSize;//粗体
+(UIFont *)italicSystemFontOfSize:(CGFloat)fontSize;//斜体

UIButton/UIImageView/UILabel的选择

  • 功能够用即可,建议不选择复杂的控件
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,298评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,701评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,078评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,687评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,018评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,410评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,729评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,412评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,124评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,379评论 2 242
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,903评论 1 257
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,268评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,894评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,014评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,770评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,435评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,312评论 2 260

推荐阅读更多精彩内容