首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

优化在 SwiftUI List 中显示大数据集的响应效率

本文将通过一个优化列表视图的案例,展现在 SwiftUI 中查找问题、解决问题的思路,其中也会对 SwiftUI 视图的显式标识、@FetchRequest 的动态设置、List 的运作机制等内容有所涉及...: id_delay_demo_2022-04-23 12.22.44.2022-04-23 12_29_07 进入视图的时候有明显的卡顿(1 秒多钟),进入后列表滚动流畅且可无延迟的响应滚动列表底部或顶部的指令...也就是当显示界面菜单时,列表视图已经完成了实例的创建(可以通过在 ListEachRowHasID 的构造函数中添加打印命令得以证明),因此也不应是实例化列表视图导致的延迟。...虽然我们已经找到了导致进入列表视图卡顿的原因,但如何在不影响效率的情况下通过 scrollTo 来实现到列表端点的滚动呢?...我们将通过 SwiftUI-Introspect[7] 来实现在 List 中滚动列表两端。

9K20

Ask Apple 2022 与 SwiftUI 有关的问答(下)

因此,如果你正在创建一个视图来显示滚动的内容,并可能进行选择操作,那么在 iOS 和 macOS 上使用 List 将有最好的体验。...阅读 The SwiftUI Layout Protocol [11]了解如何创建自定义布局。创建从底部开始的滚动视图Q:我如何实现一个在底部对齐的滚动视图,在 macOS 上会不会有糟糕的性能?...我采用了常见的解决方案,即旋转滚动视图和里面的每个单元格,以获得预期的倒置列表,在 iOS 上,这很有效。但在 macOS 上,它使 CPU 使用率保持在 100%。...定制 ListQ:是否有办法以完全定制的方式使用 List ,这样我就可以实现删除缩进、分隔线,甚至更改整个列表的背景等操作? 目前,我总是去找 LazyVStack 来代替。...但这个滚动有两大问题,1、是一个未公开的半成品,有可能会被从 SwiftUI 框架中移除;2、不支持懒加载,即使和 Lazy 视图一起使用也会一次性加载全部的视图

14.7K30
您找到你想要的搜索结果了吗?
是的
没有找到

如何判断 ScrollView、List 是否正在滚动

比如在 SwipeCell[3] 中,需要在滚动组件开始滚动时,自动关闭已经打开的侧滑菜单。遗憾的是,SwiftUI 并没有提供这方面的 API 。...方案二优点具备与 Delegate 方式几乎一致的准确性和及时性实现的逻辑非常简单方案二缺点只能运行于 iOS 系统在 macOS 下的 eventTracking 模式中,该方案的表现并不理想屏幕中只能有一个滚动控件由于任意滚动控件滚动时...,都会导致主线程的 Runloop 切换至 tracing 模式,因此无法有效地区分滚动是由那个控件造成的方法三:PreferenceKey在 SwiftUI 中,子视图可以通过 preference...proxy.frame(in: .global) ) } )}方案三优点支持多平台( iOS、macOS、macCatalyst )拥有较好的前后兼容性方案三缺点需要为滚动容器的子视图添加修饰器对于...ScrollView + VStack( HStack )这类的组合,只需为滚动视图添加一个 scrollSensor 即可。

3.7K40

WWDC 23 ,SwiftUI 5 和 SwiftData 的初印象

大幅改善了 ScrollView 的控制力 本次升级中,为 ScrollView 带来了新的动态滚动定位系统( 不依赖 ScrollViewReader 和显式的 id 声明)、一次性的定位系统( 在视图进入后...,直接定位到滚动视图的特定位置,只能使用一次 )、全新的滚动条控制( 闪烁 )、自定义行视图滚动区域的顶端和显示区域的显示状态( 例如可用其实现类似 watchOS 中的滚动到顶端子视图缩小的视觉效果...)、支持分页滚动( 开发者长期盼望的 )、自定义滚动内容的缩进、为滚动内容(非滚动容器)添加安全区域等众多功能。...订阅下方的 邮件列表[7],可以及时获得每周最新文章。...s=20 [5] 邮件列表: https://artisanal-knitter-2544.ck.page/d3591dd1e7

34810

如何在 SwiftUI 中创建条形图

在 Swift 图表中使用 Foudation 库中的测量类型 开始图表布局 SwiftUI 对探索不同布局和预览实时视图结果是很友好的。...以下列表数据被作为主视图的项目数据,每一条数据包含一个对(名称,值)。在真正的 app 里,这里的数据应该通过 ViewModel 从 model 里取数据。...图表区域保持原来的圆角矩形,并以水平堆叠的方式叠加一系列条形,每个 DataItem 一个。...图标被设置为固定大小,视图被嵌入到 ScrollView 中,以便在设备旋转时滚动。...SwiftUI 是一个很好的平台,用于创建视图和快速重构独立的子视图。在 SwiftUI 中构建条形图需要做一些工作,随着使用数据来试用条形图,可以确定更多的定制化。

5.1K10

用 Table 在 SwiftUI 下创建表格

欢迎大家在 Discord 频道[2] 中进行更多地交流 Table 是 SwiftUI 3.0 中为 macOS 平台提供的表格控件,开发者通过它可以快捷地创建交互的多列表格。...例如:标题行与数据行( 首行 )重叠;标题行第一列不显示;滚动不顺畅以及某些表现( 行高 )与 macOS 版本不一致等情况。....red : .green) } 目前的测试版 14A5228q ,当属性类型为 Bool 时,在该列上启用排序会导致应用无法编译 尽管在点击排序列标题后,仅有一个列标题显示了排序方向,但事实上 Table...请根据你的需求选择合适的替代方案: 数据量较大,需要懒加载 List、LazyVGrid 基于行的交互操作( 拖拽、上下文菜单、选择 ) List( Grid 中的 GridRow 并非真正意义上的行 ) 需要视图渲染...( 保存成图片 ) LazyVGrid、Grid 固定的标题行 List、LazyVGrid、Grid( 比如使用 matchedGeometryEffect ) 总结 如果你想在 SwiftUI 中用更少的代码

3.9K30

在 Text 中实现基于关键字的搜索和定位

image-20220822161247454点击切换按钮定位到对应的搜索结果为 TranscriptionRow 视图添加显式标识符,并通过 ScrollViewProxy 滚动到指定的位置。...请阅读 优化在 SwiftUI List 中显示大数据集的响应效率[6] 以及 避免 SwiftUI 视图的重复计算[7] 两篇文章,了解更多有关性能优化方面的内容通过 currentPostion 获取需要滚动到的...每周也会对当周博客上的新文章以及在 Twitter 上发布的 Tips 进行汇总,并通过邮件列表的形式发送给订阅者。订阅 邮件列表[14],可以及时获得每周的 Tips 汇总。...视图的重复计算: https://www.fatbobman.com/posts/avoid_repeated_calculations_of_SwiftUI_views/[8] 了解 SwiftUI.../posts/swiftUILifeCycle/[10] 在 SwiftUI 视图中打开 URL 的若干方法: https://www.fatbobman.com/posts/open_url_in_swiftUI

4.2K30

解析 SwiftUI 中两处由状态更新滞后引发的严重 Bug

这两个错误包括:通过手势取消 Sheet 后,快速右滑导航容器导致应用锁死;以及在滚动中返回上层视图时导致应用崩溃。...当视图正在滚动时返回上一层视图会导致应用崩溃这是一个由 xiaogd 在我的 Discord 论坛中提出的 问题。...它的复现条件如下:iOS 16 系统,在真机或模拟器上测试点击视图列表中的按钮,可以进入下一级视图。...请至少进入第三级视图滚动当前视图视图处于滚动状态时,点击 NavigationStack 左上角的 “Back” 按钮。...希望 SwiftUI 开发组能尽早重视这些问题。欢迎你通过 Twitter、 Discord 频道 或博客的留言板与我进行交流。订阅下方的 邮件列表,可以及时获得每周最新文章。

583110

我庆幸果断放弃了SwiftUI:它还不够成熟

并且 SwiftUI 可以“实现一次编码,适应五端 Apple 产品平台”, 包括watchOS、tvOS、macOS 等,以此统一苹果平台的 UI 框架。...跟其他创作工具一样,这款检查器的功能就是选定一个对象,并把检查的对应属性显示在一个临时的用户界面元素当中。...但在开始实现更复杂的检查器视图时,特别是涉及带有 / 不带步进器或颜色选择器的多个文本字段时,整个运行速度开始剧烈下降。...它的显示效果就是窗口中的一张表,出于学习的目的,我当然还是想继续用 SwiftUI 喽。毕竟初次尝试肯定会有种种问题,应该再给它一次机会。...如大家所见,这是个复杂的窗口,包含多种不同上下文(上方的「Sprite 资产数据库」列表,左侧的特定「Sprite 资产数据库」内容,以及其他与选定 Sprite 资产对应的编辑器元素)。

4.9K20

WWDC 23 ,SwiftUI 5 和 SwiftData 的初印象

SwiftUI 如果说从 SwiftUI 1.0 到 4.0 每年的升级是一种小修小补的行为,那么今年苹果在 SwiftUI 5.0 上做出的努力至少算得上是中期改款了。...大幅改善了 ScrollView 的控制力 本次升级中,为 ScrollView 带来了新的动态滚动定位系统( 不依赖 ScrollViewReader 和显式的 id 声明)、一次性的定位系统( 在视图进入后...,直接定位到滚动视图的特定位置,只能使用一次 )、全新的滚动条控制( 闪烁 )、自定义行视图滚动区域的顶端和显示区域的显示状态( 例如可用其实现类似 watchOS 中的滚动到顶端子视图缩小的视觉效果...)、支持分页滚动( 开发者长期盼望的 )、自定义滚动内容的缩进、为滚动内容(非滚动容器)添加安全区域等众多功能。...Editor 将 Model 转换为 SwiftData 代码,但目前问题还不少,当有多个选项,或属性类型为 transformable ,无法很好地应对 Model 原来设置的 Index,目前无法转换(生成对应的代码

1.1K20

最新iOS设计规范四|3大界面要素:视图(Views)

集合的方式不适用于文本信息,文本信息可以用列表。相对于集合,文本信息展示在一个滚动列表中,浏览起来会更简单和有效。 谨慎进行动态布局变更。集合的布局是可以随时更改的。...分列视图由一个两列或三列的界面组成,分别显示一个列,一个可选的补充列和一个辅助内容窗格。列中的更改将导致可选补充列中内容的更改。...拆分视图提供与选项卡栏相同的快速导航,同时更好地利用了大屏幕。 为每种类型的列选择适当的样式。对于显示侧栏的列,请使用侧栏外观。此外观适用于应用程序级导航和集合列表,例如Mail中的邮箱。...页眉可以出现在一中的第一项之前,页脚可以出现在最后一项之后。 ? 分组列表。行以分组的形式显示,组的上方可以出现页眉,下方则可以出现页脚。此样式的列表至少包含一个组,每个组至少包含一行。...可为“删除”按钮自定义标题。如果某行支持删除并且有助于提供清晰性,请将系统提供的删除标题替换为自定义标题。 在用户做出选择时给予相应的反馈。用户在与列表进行交互时,希望被点击的列表可以突出显示。

8.3K31

SwiftUI + Core Data App 的内存占用优化之旅

在我们创建完 100 条数据后,重启应用( 重启可以更精准地测量内存占用情况 )并滚动列表至底部。此时该应用的内存占用为 1.6 GB 左右。...无优化滚动至底截屏 从 Instruments 的分析来看,随着列表滚动,内存占用持续增加中。 无优化效果 相信任何开发者都无法容忍这种内存占用的情况出现。...当子视图进入惰性容器的可视区域时,SwiftUI 会调用它的 onAppear 闭包,子视图退出可视区域时,会调用 onDisappear 闭包。...尽管从表面上来看,惰性容器仅会在视图进入可视区域时才会对其进行操作,但一旦该视图被显示过( body 被求过值 ),即使该视图离开可视区域,SwiftUI 仍会保存视图的 body 值。...在本例中,子视图的 body 值中一定会包含用于显示的图片数据,因此,即使该视图已经被显示过( 滚动出显示区域 ),该视图的 body 值仍将占用不小的内存。

1.2K10

SwiftUI + Core Data App 的内存占用优化之旅

在我们创建完 100 条数据后,重启应用( 重启可以更精准地测量内存占用情况 )并滚动列表至底部。此时该应用的内存占用为 1.6 GB 左右。...图片 从 Instruments 的分析来看,随着列表滚动,内存占用持续增加中。 图片 相信任何开发者都无法容忍这种内存占用的情况出现。下文中,我们将对这段代码进行逐步优化,以达到最终可用的程度。...当子视图进入惰性容器的可视区域时,SwiftUI 会调用它的 onAppear 闭包,子视图退出可视区域时,会调用 onDisappear 闭包。...尽管从表面上来看,惰性容器仅会在视图进入可视区域时才会对其进行操作,但一旦该视图被显示过( body 被求过值 ),即使该视图离开可视区域,SwiftUI 仍会保存视图的 body 值。...在本例中,子视图的 body 值中一定会包含用于显示的图片数据,因此,即使该视图已经被显示过( 滚动出显示区域 ),该视图的 body 值仍将占用不小的内存。

2.4K40

解析 SwiftUI 中两处由状态更新滞后引发的严重 Bug

众所周知,SwiftUI 是一个响应式框架,这意味着,当数据源发生变化时,框架会自动更新视图。同样,当我们想调整视图显示时,应直接对状态进行修改。...这两个错误包括:通过手势取消 Sheet 后,快速右滑导航容器导致应用锁死;以及在滚动中返回上层视图时导致应用崩溃。...当视图正在滚动时返回上一层视图会导致应用崩溃 这是一个由 xiaogd 在我的 Discord 论坛中提出的 问题[3]。...它的复现条件如下: iOS 16 系统,在真机或模拟器上测试 点击视图列表中的按钮,可以进入下一级视图。...请至少进入第三级视图 滚动当前视图视图处于滚动状态时,点击 NavigationStack 左上角的 “Back” 按钮。

26220

SwiftUI 的方式进行布局

准备工作 我们首先将一些复用的代码提取出来,以简化之后的工作: // 视图一 struct RedView: View { var body: some View { Rectangle...四、ScrollView 考虑到本文需求的动画形态( 竖向滚动 ),使用 ScrollViewReader 提供的滚动定位功能,同样可以满足需求。...ScrollView 会使用父视图给定的全部建议尺寸创建滚动区域,但在询问其子视图的需求尺寸时只会提供理想尺寸。...SwiftUI 在进行布局时,当布局容器给出的建议尺寸无法满足全部子视图的需求尺寸时,会根据子视图的 Priority,优先满足级别较高的视图的布局需求。...七、Transition 通过为视图设定 Transition( 转场 ),在视图插入或将其移出视图树时,SwiftUI 将自动生成对应的动画效果。

3.2K00

iOS 9人机界面指南(四):UI元素(上) - 腾讯ISUX

如果在导航栏中使用了分段控件,请确保返回按钮标题命名的准确。(更多使用指引请参阅本章第三中的分段控件。) ?...有时候用户会觉得以列表呈现的信息更容易阅读和理解,例如将文本信息放在滚动列表中的时候,用户阅读和处理起来会更为简单和高效。 让视图中的项更容易选中。...4.2.11 表格视图 表格视图以一个滚动的单列多行的形式来展示数据。 ?...添加这些元素会缩小标题以及副标题单元格的可用宽度。 使用表格视图可以简洁而高效地展示少量或者大量信息。举例来说,你可以通过表格视图来: 展示用户可选的选项列表。...使用表格视图时,遵循以下这些指引: 用户选择列表项时,始终给与反馈。当用户点击可选的列表项时会认为被点击的项都应短暂地高亮一下。

10.1K51
领券