iOS开发-VFL初窥
VFL是苹果为了简化Autolayout的编码而推出的抽象语言,在上一篇博客中我们发现如果使用NSLayoutConstraint来添加约束是非常繁琐的。
一个简单的Frame需要添加四个NSLayoutConstraint才能完成约束,VFL则可以完美的解决这个问题,但VFL也有缺点,VFL如果书写有错编译器不会提示,直到运行时才会报错。
从上图中可以看出两个Button在UI界面上的相对关系转换成VFL就是“[cancelButton]-[acceptButton]”,使用起来非常的便捷。
VFL示例
H:[cancelButton(72)]-12-[acceptButton(50)]
canelButton宽72,acceptButton宽50,它们之间间距12
H:[wideView(>=60@700)]
wideView宽度大于等于60point,该约束条件优先级为700(优先级最大值为1000,优先级越高的约束越先被满足)
V:[redBox]-[yellowBox(==redBox)]
竖直方向上,先有一个redBox,其下方紧接一个高度等于redBox高度的yellowBox
H:|-10-[Find]-[FindNext]-[FindField(>=20)]-|
水平方向上,Find距离父view左边缘默认间隔宽度,之后是FindNext距离Find间隔默认宽度;再之后是宽度不小于20的FindField,它和FindNext以及父view右边缘的间距都是默认宽度。(竖线“|” 表示superview的边缘)
VFL的使用
使用VFL来创建约束数组
+ (NSArray *)constraintsWithVisualFormat:(NSString *)format options:(NSLayoutFormatOptions)opts metrics:(NSDictionary *)metrics views:(NSDictionary *)views;
format :VFL语句
opts :约束类型
metrics :VFL语句中用到的具体数值
views :VFL语句中用到的控件 创建一个字典(内部包含VFL语句中用到的控件)的快捷宏定义
NSDictionaryOfVariableBindings(...)
VFL在创建约束时仍然有一定的局限性,比如两个Button:A、B,A的宽度是B的宽度的一半,此时必须使用NSLayoutConstraint方式来进行约束。
基于Autolayout的动画效果
在使用Frame来约束控件时,我们通常是在animateWithDuration方法体中修改Frame。
使用Autolayout时,在修改了约束之后,只要执行下面代码,就能做动画效果
[UIView animateWithDuration:1.0 animations:^{
[添加了约束的view layoutIfNeeded];
}];
如果觉得还不错,打赏下买个饮料
最新文章
- ecshop 点击领取红包
- 全架构PaaS TAE 2.0的Docker实践
- 【No.4 Ionic】修改 cordova 插件
- Java中的并发线程操作(只贴代码,内有注释)
- mac下使用Solarized配色方案
- java 参数化类型
- javascript学习小记(一)
- 数据库系统——B+树索引
- SQL Server Compact免安装部署
- JavaScript中JSON字符串和JSON对象相互转化
- js模块化加载器实现
- webpack2.x基础属性讲解(一)
- Android 4.0以后正确的获取外部sd卡存储目录
- js面试题知识点全解(一变量类型和计算)
- [2012-05-31]awk去重复项
- 项目Beta冲刺Day6
- python 关于django 2.X from django.contrib.auth.views import login
- oracle 学习笔记(2)创建表空间及用户授权
- Qt ------ 自定义QVector<;T>;中的T
- java多线程分块上传并支持断点续传最新修正完整版本[转]
热门文章
- Java设计模式(22)命令模式(Command模式)
- 为已经存在的本地项目添加git,以及从远程仓库拉取代码并切换远程分支
- Mayi_XPath编写规则学习
- IO多路复用的机制:select、poll、epoll
- [2013.7.5新鲜出炉] Ubuntu12.04下载Android4.0.1源码全过程----------------折腾两天,终于下好,附若干问题解决
- win10 .net framework 3.5无法安装错误代码0x800F081F
- 第一個shell腳本
- sublime3 docblocker插件定制自己的注释,配置步骤
- nodejs npm 使用淘宝 NPM 镜像
- 查看cp进度,使用watch