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];
}];

如果觉得还不错,打赏下买个饮料

最新文章

  1. ecshop 点击领取红包
  2. 全架构PaaS TAE 2.0的Docker实践
  3. 【No.4 Ionic】修改 cordova 插件
  4. Java中的并发线程操作(只贴代码,内有注释)
  5. mac下使用Solarized配色方案
  6. java 参数化类型
  7. javascript学习小记(一)
  8. 数据库系统——B+树索引
  9. SQL Server Compact免安装部署
  10. JavaScript中JSON字符串和JSON对象相互转化
  11. js模块化加载器实现
  12. webpack2.x基础属性讲解(一)
  13. Android 4.0以后正确的获取外部sd卡存储目录
  14. js面试题知识点全解(一变量类型和计算)
  15. [2012-05-31]awk去重复项
  16. 项目Beta冲刺Day6
  17. python 关于django 2.X from django.contrib.auth.views import login
  18. oracle 学习笔记(2)创建表空间及用户授权
  19. Qt ------ 自定义QVector<T>中的T
  20. java多线程分块上传并支持断点续传最新修正完整版本[转]

热门文章

  1. Java设计模式(22)命令模式(Command模式)
  2. 为已经存在的本地项目添加git,以及从远程仓库拉取代码并切换远程分支
  3. Mayi_XPath编写规则学习
  4. IO多路复用的机制:select、poll、epoll
  5. [2013.7.5新鲜出炉] Ubuntu12.04下载Android4.0.1源码全过程----------------折腾两天,终于下好,附若干问题解决
  6. win10 .net framework 3.5无法安装错误代码0x800F081F
  7. 第一個shell腳本
  8. sublime3 docblocker插件定制自己的注释,配置步骤
  9. nodejs npm 使用淘宝 NPM 镜像
  10. 查看cp进度,使用watch