iOS系统自带的自动布局--NSLayoutContraint

本文介绍了在iOS开发中如何使用系统自带的NSLayoutContraint进行自动布局,强调了不需要设置frame以避免冲突,并通过示例代码详细展示了创建约束的过程。同时提到了在设置自动布局时需要将translatesAutoresizingMaskIntoConstraints设为NO,以防系统默认约束产生冲突。最后预告了将要介绍的第三方自动布局框架Masonry,以解决手动布局代码繁多的问题。
摘要由CSDN通过智能技术生成

前言
自动布局,我们一般可以直接使用Storyboard和xib完成,但在一个真正的项目中,单纯地使用故事版和xib是远远不够的,在很多地方都需要纯代码的参与,为了更好地满足项目的需求,就需要要我们手工实现了。然,纯代码的自动布局有好几种方式,iOS系统自带的NSLayoutContraint, 还有现在有名的第三方屏幕适配的自动布局的第三方开源框架Masonry,今天,让我们先学习系统自带的NSLayoutContraint, 后面再接着来学习Masonry。


1 一般而言,如果我们使用系统的自动布局NSLayoutContraint,就不需要给View添加frame属性了,因为两者在某些程度上会产生冲突。

创建一个红色的View:

 UIView *redView = [[UIView alloc] init];
 redView.backgroundColor = [UIColor redColor];
 [self.view addSubview:redView];

2 需要注意的是,我们使用NSLayoutContraint自动布局的时候,还需要同时设置属性 translatesAutoresizingMaskIntoConstraints = NO:

redView.translatesAutoresizingMaskIntoConstraints = NO;

因为这是系统默认提供的自动定制大小布局约束的属性,比如我们直接在Storyboard上拖拽一个View,不用设置任何自动布局,run之后依然会显示在屏幕(模拟器)上,也就是说系统会默认给我们添加一些简单的约束,默认为 YES。如果不设置,则会和我们用NSLayoutContraint自动布局产生冲突,这样的情况下,视图或将不显示,或者run eruption。

3 直接上代码,注释在其中

//红色视图距离左边=当前视图(父视图&#x
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值