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

深入了解 SwiftUI 5 中 ScrollView 的新功能

可采用 优化在 SwiftUI List 中显示大数据集的响应效率[5] 一文中介绍的方式来解决。 scrollPostion(id:) 使用此修饰符可以让滚动视图滚动到特定的位置。...(视图标识) 不支持锚点设定,固定锚点为子视图的 center 正如 优化在 SwiftUI List 中显示大数据集的响应效率[6] 一文所提到的,当数据集很大时,也会出现性能问题。...就我个人而言,在 SwiftUI 5 中,ScrollView 的原生方案已经能够满足大多数需求,因此我们将看到更多人采用 ScrollView + LazyStack 的组合方式。...的 Safe Area: https://www.fatbobman.com/posts/safeArea/ [5] 优化在 SwiftUI List 中显示大数据集的响应效率: https://www.fatbobman.com.../posts/optimize_the_response_efficiency_of_List/ [6] 优化在 SwiftUI List 中显示大数据集的响应效率: https://www.fatbobman.com

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

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

遗憾的是,SwiftUI 并没有提供这方面的 API 。本文将介绍几种在 SwiftUI 中获取当前滚动状态的方法,每种方法都有各自的优势和局限性。...Bool)手指拖动结束后( 手指离开时 ),调用此方法在 SwiftUI 中,很多的视图控件是对 UIKit( AppKit )控件的二次包装。...和 List .introspectScrollView { scrollView in scrollView.delegate = delegate...目前 SwiftUI 在内部的实现上去 UIKit( AppKit )化很明显,比如,本节介绍的方法在 SwiftUI 4.0 中已经失效方法二:Runloop我第一次接触 Runloop 是在学习 Combine...preference 与 onChange 的调用时机非常类似,只有在值发生改变后才会传递数据。在 ScrollView、List 发生滚动时,它们内部的子视图的位置也将发生改变。

3.7K40

SwiftUI-数据

SwiftUI中的界面是严格数据驱动的:运行时界面的修改,只能通过修改数据来间接完成,而不是直接对界面进行修改操作。...A Single Source Of Truth: 保持单一数据源,在 SwiftUI 中不同视图之间如果要访问同样的数据,不需要各自持有数据,直接共用一个数据源即可,这样做的好处是无需手动处理视图和数据的同步...ObservableObject 在应用开发过程中,很多数据其实并不是在 View 内部产生的,这些数据有可能是一些本地存储的数据,也有可能是网络请求的数据,这些数据默认是与 SwiftUI 没有依赖关系的...数据流图 从上图可以看出SwiftUI数据流转过程: 用户对界面进行操作,产生一个操作行为 action 该行为触发数据状态的改变 数据状态的变化会触发视图重绘 SwiftUI 内部按需更新视图,...最终再次呈现给用户,等待下次界面操作 注意 在 SwiftUI 中,开发者只需要构建一个视图可依赖的数据源,保持数据的单向有序流转即可,其他数据和视图的状态同步问题 SwiftUI 帮你管理,所以 ViewController

10K20

GeometryReader :好东西还是坏东西?

,我们也能持续更新数据。...task(id:) 同时涵盖了 onAppear 和 onChange 的场景,是最可靠的数据获取方式。 另外,在某些情况下,GeometryReader 有可能返回尺寸为负数的数据。...如果直接将这些负数数据传递给 frame,就可能会出现布局异常(在调试状态下,Xcode 会用紫色的提示警告开发者)。因此,为了进一步避免这种极端情况,可以在传递数据时,将不符合要求的数据过滤掉。...在处理类似需求时,我们应优先采用更符合 SwiftUI 的思维方式来考虑布局方案,而非依赖某个特定的几何数据进行计算。...里子和面子:不同的尺寸数据SwiftUI 中,有一些 modifier 是在布局之后,在渲染层面对视图进行的调整。

45670

SwiftUI 与 Core Data —— 数据获取

本文中我们将探讨在 SwiftUI 视图中批量获取 Core Data 数据的方式,并尝试创建一个可以使用 mock 数据的 FetchRequest。...SwiftUI 与 Core Data —— 问题[2]SwiftUI 与 Core Data —— 数据定义[3]访问我的博客 www.fatbobman.com[4] 可以获得更好的阅读体验以及最新的更新内容...在 SwiftUI 中,ForEach 会根据数据标识( Identifier )自动处理视图的添加、删除等操作,因此,当在 SwiftUI 中使用 NSFetchedResultsController...DynamicProperty 协议为数据提供了访问 SwiftUI 托管数据池的能力。通过未公开的 _makeProperty 方法,数据可以在 SwiftUI 数据池中申请空间进行保存并读取。...这样可以减少 ForEach 数据集的变化频次,改善 SwiftUI 的视图效率。

4.6K30

SwiftUI 与 Core Data —— 数据定义

在今后的文章中我们将尝试用新的思路来创建一个 SwiftUI + Core Data 的 app,看看能否避免并改善之前的一些问题。本文将首先探讨如何定义数据。...无需更改代码便可以适应不同的框架( 纯 SwiftUI 驱动、TCA 或其他的 Redux 框架 )所有的视图均可以实现在不使用任何 Core Data 代码的情况下进行预览,并可对 Mock 数据进行动态响应...对于 SwiftUI 来说,托管对象具备两个非常显著的特点:懒加载托管对象的所谓托管是指:该对象被托管上下文所创建并持有。仅在需要的时候,才从数据库( 或行缓存 )中加载所需的数据。...这个类型除了用于为 SwiftUI 的视图提供数据外,同时也会被用于为其他的数据流提供有效信息,例如,在类 Redux 框架中,通过 Action 为 Reducer 提供所需数据。...视图: https://www.fatbobman.com/posts/coreDataInPreview/#为_SwiftUI_预览提供_Core_Data_数据[5] 这点已经在 Ask Apple

2.4K40

SwiftUI 的方式进行布局

最近时常有朋友反映,尽管 SwiftUI 的布局系统学习门槛很低,但当真正面对要求较高的设计需求时,好像又无从下手。SwiftUI 真的具备创建复杂用户界面的能力吗?...不过需要注意的是,NameSpace 只适用于在同一棵视图树中分享数据,如果出现了例如 一段因 @State 注入机制所产生的“灵异代码”[6] 一文中提到了两棵树的情况,则无法实现几何信息的共享。...四、ScrollView 考虑到本文需求的动画形态( 竖向滚动 ),使用 ScrollViewReader 提供的滚动定位功能,同样可以满足需求。...ScrollView 会使用父视图给定的全部建议尺寸创建滚动区域,但在询问其子视图的需求尺寸时只会提供理想尺寸。...scrollDisabled( 则让我们可以在 iOS 16+ 中屏蔽 ScrollView 的滚动手势 )。

3.2K00

SwiftUI 的方式进行布局

最近时常有朋友反映,尽管 SwiftUI 的布局系统学习门槛很低,但当真正面对要求较高的设计需求时,好像又无从下手。SwiftUI 真的具备创建复杂用户界面的能力吗?...不过需要注意的是,NameSpace 只适用于在同一棵视图树中分享数据,如果出现了例如 一段因 @State 注入机制所产生的“灵异代码” 一文中提到了两棵树的情况,则无法实现几何信息的共享。...四、ScrollView 考虑到本文需求的动画形态( 竖向滚动 ),使用 ScrollViewReader 提供的滚动定位功能,同样可以满足需求。...ScrollView 会使用父视图给定的全部建议尺寸创建滚动区域,但在询问其子视图的需求尺寸时只会提供理想尺寸。...scrollDisabled( 则让我们可以在 iOS 16+ 中屏蔽 ScrollView 的滚动手势 )。

4.7K80

SwiftUI 下使用 NSUbiquitousKeyValueStore 同步数据

SwiftUI 下使用 NSUbiquitousKeyValueStore 同步数据 可以访问我的博客 www.fatbobman.com[1] ,获得更好的阅读体验 NSUbiquitousKeyValueStore...本文将对其用法做以简单介绍,着重探讨如何便捷地在 SwiftUI 中使用 NSUbiquitousKeyValueStore。...•NSUbiquitousKeyValueStore 尚未提供 SwiftUI 下的便捷使用方法 从 iOS 14 开始,苹果为 SwiftUI 提供了 AppStorage,同对待@State 一样,...在 SwiftUI 视图中使用 NSUbiquitousKeyValueStore 本节中,我们将在不使用任何第三方库的情况下,实现 SwiftUI 视图对 NSUbiquitousKeyValueStore...在不使用第三方库的情况下,在 SwiftUI 视图中可以通过桥接@State 数据的形式,将 NSUbiquitousKeyValueStore 的变化同视图联系起来。

4.9K40

解析SwiftUI布局细节(二)循环轮播+复杂布局

我们看看最底层的代码先: NavigationView{ ScrollView(showsIndicators:false,content: {...3、再提一点关于上面说的滚动视图,在UIKit中我们可以用UICollectionView搞定一切,但是在SwiftUI中没有这个控件,我建议采用的方式是 ScrollView + HStack + VStack...的方式去实现,很多同行有说目前来看SwiftUI的List在数据量大的情况下性能不是特别好,采用ScrollView是个不错的方式,而且也很容易构建出来,并不是说每一个Item的位置都需要你去计算,...1就是数据没有被处理之前的0位置的图片 /// 所以这里默认从1开始 @State var currentIndex: Int = 1 /// 是否需要动画 @State...之GeometryReader 理解SwiftUI关键字 State Binding ObservesOgiect EnvironmentObje SwiftUI 自定义实现旋转木马轮播效果

11.8K20

Python-数据解析-职位信息-中

urllib.request.urlopen(request) html = response.read().decode("utf-8") return html 一、使用正则、lxml、bs4 解析职位数据...在爬取了整个网页之后,下一步就是从整个 HTML 中提取目标数据。...① 使用 re 模块解析网页数据 根据前面所分析的网页源代码; 查找所有的职位名称。 在 HTML 源代码中,职位名称对应的文本位于标签 中。首先,以 (.*?)... 查找所有的职位详情链接。 职位详情链接的文本位于开始标签 中,且 中有着唯一的属性,可以与其它 进行区分。...> 查找职位类别、招聘人数、地点、发布时间。 职位类别、招聘人数、地点、发布时间对应的文本都位于开始标签 和结束标签 中。 (.*?)

94230

SwiftUI 视图的生命周期研究

SwiftUI 视图的生命周期 大多介绍 SwiftUI 视图生命周期的文章,通常会将视图的生命周期描述成如下的链条: 初始化视图实例——注册数据依赖——调用 body 计算结果——onAppear——...但 SwiftUI 并非一定会从新的实例中获取 body 结果,如果之前的实例注册过数据依赖,视图值树仍可能会从原来的实例的 body 中获取结果。...这样即使 SwiftUI 创建了多余的实例,也不会加大系统的负担。 注册数据依赖 在 SwiftUI 中,状态(或者说是数据)是驱动 UI 的动力。...通常情况下,SwiftUI 在需要渲染屏幕某个区域或需要该区域的数据配合布局时,会在视图值树上创建对应的视图。当不再需要其参与布局或渲染时视图将被销毁。...比如在 List 和 LazyVStack 中,Cell 视图在创建之后即使滚动出屏幕不参与布局与渲染,但 SwiftUI 仍会保留这些视图的数据,直到 List 或 LazyVStack 被销毁。

4.3K30

Python-数据解析-职位信息-上

爬取腾讯社会招聘网站的招聘信息,包括职位名称、职位类别、招聘人数、工作地点、发布时间、以及每个职位详情的链接。 ? 一、 分析要解析的数据 第一个职位所在的标签 ,该标签中既有属性,又有文本。...href 属性: 每个职位详情的链接(后半部分)。如果要了解职位的详情,需要在 href 属性值的前面加上 http://hr.tencent.com/,拼接成一个完整的链接。...文本: 表示职位的名称。 再查看其它相邻的标签 ,可以发现,这些标签所对应的文本分别表示“职位类别”、“招聘人数”、“工作地点”、“发布时间”。...因此,只要拿到这些标签的文本,就能拿到想要的数据。 还可以查看其它标签的内容,以确认所要解析的数据。查看下一个标签 ,该标签的内容对应着第二条招聘信息。...因此, 和 标签中的文本和 href 属性都是要筛选出来的数据。 ?

1K20

数据行业的热门职位有哪些?

一般我们把数据科学与大数据领域的角色分成4类:数据架构师、数据分析师、数据科学家、数据工程师。...以下是热门的大数据岗位: 大数据开发工程师 数据仓库开发、实时计算开发、大数据平台开发一般都会被称作大数据开发,其实这是3个岗位,各自要求也不尽相同。...大数据分析师 基于各种分析手段,利用大数据技术对大数据进行科学分析、挖掘、展现并用于决策支持。 数据挖掘工程师 数据挖掘工程师,也可以叫做“数据挖掘专家”。...数据挖掘是通过分析每个数据,从大量数据中寻找其规律的技术。 算法工程师 数据挖掘、互联网搜索算法这些体现大数据发展方向的算法,在近几年越来越流行,而且算法工程师也逐渐朝向人工智能的方向发展。...数据安全研究 数据安全这一职位,主要负责企业内部大型服务器、存储、数据安全管理工作,并对网络、信息安全项目进行规划、设计和实施。

71530

WWDC 23 ,SwiftUI 5 和 SwiftData 的初印象

全新的数据流声明和注入方式 利用 Swift 5.9 的新特性,对于引用类型的 Source of truth,只需使用 @Observable 进行标注,视图将对数据源的变化以属性为粒度进行响应。...这从根本上解决了当前影响 SwiftUI 应用( 过渡计算 )的效率问题。让开发者可以更加自由的来设计数据结构以及随心所欲的注入数据源。 不过很遗憾,这项新特性只能在 SwiftUI 5 上实现。...由于在同一个系统中存在了两种不同的数据源声明逻辑,这也给初学者带来了更多的困扰。...大幅改善了 ScrollView 的控制力 本次升级中,为 ScrollView 带来了新的动态滚动定位系统( 不依赖 ScrollViewReader 和显式的 id 声明)、一次性的定位系统( 在视图进入后...与之前的预判一样,在数据存储领域,苹果不会贸然地另起炉灶,创建一套全新的逻辑。

1.1K20
领券