UIScrollView 遇到了AutoLayout之后其contentSize 的计算

UIScrollView 的特殊之处就在于当它遇到了AutoLayout之后其contentSize 的计算规则有些特殊。
contentSize是根据子视图的leading/trailing/top/bottom进行确定的

所以避免我们手动去设置 contentSize,我们必须迎合它的规则去设置

复制代码
       let scrollView = UIScrollView()
        
        scrollView.backgroundColor = .gray
        view.addSubview(scrollView)
        scrollView.snp.makeConstraints { (make) in
            make.edges.equalToSuperview()
        }
        let containerView = UIView()
        containerView.backgroundColor = .blue
        scrollView.addSubview(containerView)
        containerView.snp.makeConstraints { (make) in
            make.edges.equalToSuperview()
            make.width.equalToSuperview()
        }
        
        let view1 = UIView()
        view1.backgroundColor = .orange
        
        let view2 = UIView()
        view2.backgroundColor = .blue
        
        
        containerView.addSubview(view1)
        containerView.addSubview(view2)
        
        view1.snp.makeConstraints { (make) in
            make.top.equalToSuperview()
            make.width.equalToSuperview()
            make.height.equalTo(500)
        }
        
        view2.snp.makeConstraints { (make) in
            make.top.equalTo(view1.snp.bottom)
            make.bottom.equalTo(containerView.snp.bottom)
            make.leading.trailing.equalTo(containerView)
            make.width.equalToSuperview()
            make.height.equalTo(500)
        }
复制代码

大概就是这意思,我们通过一个填满的 containerView 去设置子视图,同时我们最后一个 subview 的 bottom 一定要与 containerView 对齐即可

来源https://segmentfault.com/a/1190000037456477

posted @   甘林梦  阅读(190)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2016-03-25 归档NSKeyedArchiver解归档NSKeyedUnarchiver与文件管理类NSFileManager (文件操作)
点击右上角即可分享
微信分享提示