SwiftUI 6.0(iOS 18)将 Sections 也考虑进自定义容器子视图布局(上)

news2024/10/12 10:17:19

在这里插入图片描述

概述

在 WWDC 24 新推出的 SwiftUI 6.0 中,苹果对于容器内部子视图的布局有了更深入的支持。为了能够未雨绸缪满足实际 App 中所有可能的情况,我们还可以再接再厉,将 Sections 的支持也考虑进去。

在这里插入图片描述

SwiftUI 6.0 对容器子视图布局的增强支持可以认为是一个小巧的容器自定义布局(Custome Layout)简化器。

在本篇博文中,您将学到如下内容:

  • 概述
  • 1. SwiftUI 6.0 容器内容的遍历和重新组合
  • 2. SwiftUI 6.0 中新的容器子视图布局考量
  • 3. 容器子视图的遍历
  • 4. 容器子视图的重新组合
  • 总结

有了全新容器子视图布局机制的加持,现在对于任何需要适配自定义容器行为的情况我们都可以游刃有余、从容应对了!

那还等什么呢?Let‘s go!!!😉


1. SwiftUI 6.0 容器内容的遍历和重新组合

苹果在 SwiftUI 4.0(iOS 16)中推出了自定义容器布局(Custom Layout)功能,有了它我们即可放心大胆的创建具有独特外观和行为的容器了:

在这里插入图片描述

Layout 协议弥补了 SwiftUI 不能自定义容器布局之遗憾,将容器中子视图渲染位置的自由度发挥到了极致。


更多关于容器自定义布局的使用和介绍,请小伙伴们移步如下链接观赏精彩的内容:

  • SwiftUI 打造一款收缩自如的 HStack(四):Layout 自定义布局

不过,有时候我们仅仅希望稍微调整一下现有容器子视图的布局,比如换成系统默认的现成容器(VStack、HStack、ZStack 等)。在这种情况下使用自定义容器布局 Layout 略显大材小用了。

于是乎,在 SwiftUI 6.0(iOS 18)中苹果给了我们另一套“组合拳”:容器内容的遍历(ForEach)和再组合(Group)。

2. SwiftUI 6.0 中新的容器子视图布局考量

简单来说,在 SwiftUI 6.0 中我们可以使用 ForEach 和 Group 的新构造器来实现容器内容的遍历(探囊取物)和重新组合(聚沙成塔)。前者可以帮助我们方便的将 @ViewBuilder 传入的内容分解为单个容器的子元素,而后者则能让我们在容器整体布局的重构上一展拳脚。

在 SwiftUI 6.0 之前,如果我们想实现一个自定义的 Card 容器可能会这样做:

struct Card<Content: View>: View {
   
    @ViewBuilder var content: Content
    
    var body: some View {
   
        VStack {
   
            content
        }
        .padding()
        .background(Material.regular, in: .rect(cornerRadius: 8))
        .shadow(radius: 4)
    }
}

然后这样来使用它:

struct ContentView: View {
   
    var body: some View {
   
        Card {
   
            Text("Hello, World!")
            Text("My name is Majid Jabrayilov")
        }
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2207710.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Wordpress—一个神奇的个人博客搭建框架

wordpress简介 在当今数字化的时代&#xff0c;拥有一个属于自己的个人博客&#xff0c;不仅可以记录生活点滴、分享专业知识&#xff0c;还能展示个人风采。而在众多的博客搭建框架中&#xff0c;Wordpress 以其强大的功能和灵活性脱颖而出。今天&#xff0c;就让我们一起深入…

spring boot项目日志怎么加?

使用源码LoggerFactory&#xff08;日志工厂类&#xff09; 使用方法&#xff1a;getlogger()中间传入1个类 加在过滤里所以需要传入的是过滤这个类&#xff08;reqfilter.class) 用这个对象调info方法 logger.error是打印错误信息 logger.debug打印debug 结果会增加时间名称等…

LQB焊接超声波部分原理图和焊接说明(勘误)

1、自制的板子的原理图&#xff0c;有一个错误的地方&#xff0c;导致超声波不能正常使用。 下图是实物的原理图存在错误&#xff0c;不小心&#xff0c;自我批评一下。 图中的C6电容330pF的一端接到了VCC&#xff0c;是错误的。 蓝桥杯的原理图是下图&#xff0c;接到GND 因…

【机器学习(十三)】机器学习回归案例之股票价格预测分析—Sentosa_DSML社区版

文章目录 一、背景描述二、Python代码和Sentosa_DSML社区版算法实现对比(一) 数据读入(二) 特征工程(三) 样本分区(四) 模型训练和评估(五) 模型可视化 三、总结 一、背景描述 股票价格是一种不稳定的时间序列,受多种因素的影响。影响股市的外部因素很多,主要有经济因素、政治因…

51单片机数码管循环显示0~f

原理图&#xff1a; #include <reg52.h>sbit dulaP2^6;//段选信号 sbit welaP2^7;//位选信号unsigned char num;//数码管显示的数字0~funsigned char code table[]{ 0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71};//定义数码管显…

CDN服务支持多种应用场景,包括图片、大文件下载、流媒体等

中国联通国际公司产品之 CDN&#xff08;内容分发网络&#xff09; 在当今这个信息爆炸的时代&#xff0c;内容分发网络&#xff08;CDN&#xff09;已成为提升用户体验和保障数据快速传输的重要工具。中国联通国际公司凭借其全球领先的通信技术和广泛的网络覆盖&#xff0c;推…

Qualitor checkAcesso.php 任意文件上传漏洞复现(CVE-2024-44849)

0x01 漏洞概述 Qualitor 8.24及之前版本存在任意文件上传漏洞,未经身份验证远程攻击者可利用该漏洞代码执行,写入WebShell,进一步控制服务器权限。 0x02 复现环境 FOFA:app="Qualitor-Web" 0x03 漏洞复现 PoC POST /html/ad/adfilestorage/request/checkAcess…

第十一章 RabbitMQ之消费者确认机制

目录 一、介绍 二、演示三种ACK方式效果 2.1. none: 不处理 2.1.1. 消费者配置代码 2.1.2. 生产者主要代码 2.1.3. 消费者主要代码 2.1.4. 运行效果 2.2. manual&#xff1a;手动模式 2.3. auto&#xff1a;自动模式 一、介绍 消费者确认机制&#xff08;Consume…

物流大数据底盘建设方案

1、现状及目标 1.1、离线数仓现状及目标 1.2、实时数仓现状及目标 2、建设方向 2.1、建设概览 2.2、数仓架构重建 2.3、数据架构 2.4、作业优化 2.5、具体作业优化-运营 2.6、具体作业优化-财经 2.7、数据血缘依赖重构 2.8、事实表建设思路 2.9、公共维表建设思路 2.10、数据…

springboot-网站开发-使用slf4j实现网站异常错误的及时跟踪定位

springboot-网站开发-使用slf4j实现网站异常错误的及时跟踪定位&#xff01;项目部署&#xff0c;开发好后&#xff0c;部署到远程服务器上面了&#xff0c;运行过程中&#xff0c;难免会遇到一些错误和异常情况&#xff0c;我们需要借助一些插件来帮助我们及时捕捉这类错误和异…

【中文版】深度学习 deep learning 花书 pdf下载 2017.09.04

中文版pdf&#xff1a;https://pan.baidu.com/s/1s93yluQGSly5uBDAIVAlNg?pwdx6xy github&#xff1a;https://github.com/exacity/deeplearningbook-chinese 目录 第一章 前言第二章 线性代数第三章 概率与信息论第四章 数值计算第五章 机器学习基础第六章 深度前馈网络第七…

一道Fortran题(Fortran)

题目 代码 选择排序法 结果 我勒个&#xff01;

【项目管理】如何根据 PV、EV、AC 计算 CPI 和 SPI?

【项目管理】如何根据 PV、EV、AC 计算 CPI 和 SPI&#xff1f; 一、PV&#xff08;计划价值 - Planned Value&#xff09;二、EV&#xff08;挣值 - Earned Value&#xff09;三、AC&#xff08;实际成本 - Actual Cost&#xff09;四、CV&#xff08;成本偏差 - Cost Varianc…

C# WPF 仿 Android Toast 效果

转载请注明出处: https://blog.csdn.net/hx7013/article/details/142860084 主职Android, 最近需要写一些WPF的程序作为上位机&#xff0c;目前WPF的MessageBox过于臃肿&#xff0c;且想找一个内置的非阻塞的简单提示一直找不到&#xff0c;想到了Android的Toast所以写了这个扩…

Kafka之生产者

本章内容将整理下Kafka体系结构中的生产者相关的一些知识。 1. 生产者客户端 生产者客户端在Kafka的发展历程当中一共有两个重大版本&#xff1a; 一个是基于Scala语言开发的版本&#xff0c;称为Old Producer或Scala版的生产者客户端。一个是Kafka0.9.x版本之后以Java语言开发…

《深度学习》OpenCV 光流估计 原理、案例解析

目录 一、光流估计 1、什么是光流估计 2、原理 3、光流估计算法 1&#xff09;基于局部方法 2&#xff09;和基于全局方法 4、光流估计的前提 1&#xff09;亮度恒定 2&#xff09;小运动 3&#xff09;空间一致 二、案例实现 1、读取视频 2、特征检测 3、处理每…

Python | Leetcode Python题解之第474题一和零

题目&#xff1a; 题解&#xff1a; class Solution:def findMaxForm(self, strs: List[str], m: int, n: int) -> int:count10 []for s in strs:count10.append([0,0])for c in s:if c 0: count10[-1][0]1else: count10[-1][1]1dp [[0]*(n1) for _ in range(m1)]for i …

十一、数据库的设计规范

文章目录 1. 为什么需要数据库设计2. 范式2.1 范式介绍2.2 范式都包括哪些2.3 键和相关属性的概念2.4 第一范式(1st NF)2.5 第二范式(2nd NF)2.6 第三范式(3rd NF)2.7 小结3. 反范式化3.1 概述3.2 应用举例3.3 反范式的新问题3.4 反范式的使用场景3.4.1 增加冗余字段的建议3.…

windows系统更新升级node指定版本【避坑篇!!!亲测有效】(附带各版本node下载链接)一定看到最后!不用删旧版!

Node.js 是一个开源、跨平台的 JavaScript 运行时环境&#xff0c;广泛应用于服务器端和网络应用的开发。随着 Node.js 版本的不断更新&#xff0c;我们可能需要升级到特定版本以满足项目需求或修复安全漏洞。又或者是学习开发另外一个新项目&#xff0c;新项目对Node版本要求更…

上交大全华班复现o1旅程式学习下的深思考

因篇幅限制不重复原研究内容&#xff0c;建议访问原技术报告链接精读&#xff0c;这里主要向大伙表示我对上交大本此研究所涉三方面的价值认同及更进一步的延展思考。 价值认同&#xff1a; ① 深刻洞察&#xff1a;系统性研究并阐释旅程式学习&#xff1b; ② 行业促进&…