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

深入了解 SwiftUI 5 ScrollView 新功能

SwiftUI 5.0 ,苹果大幅强化了 ScrollView 功能。新增了大量新颖、完善 API。本文将对这些新功能进行介绍,希望能够让它们更多、更早帮助到有需要开发者。...某些场景下,效果与 safeAreaInset 十分相似。例如,在下面的代码,为 ScrollView leading 方向添加安全区域两种方式效果是一致。...当 scrollClipDisable 为 false 时,滚动内容会被裁剪以适应滚动容器边界。任何超出边界部分将不会显示。...它可以延伸超出滚动容器边界,从而显示更多内容。...总结 我完全没有想到, SwiftUI 5 ,苹果对 ScrollView 进行了全面增强。值得赞赏是,他们不仅提供了一些一直期待功能,而且 API 设计和实现完成度上都非常出色。

67620

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

欢迎大家 Discord 频道[2] 中进行更多地交流判断一个可滚动控件( ScrollView、List )是否处于滚动状态某些场景下具有重要作用。...本文将介绍几种 SwiftUI 获取当前滚动状态方法,每种方法都有各自优势和局限性。...: UIScrollView, willDecelerate decelerate: Bool)手指拖动结束后( 手指离开时 ),调用此方法 SwiftUI ,很多视图控件是对 UIKit( AppKit...目前 SwiftUI 在内部实现上去 UIKit( AppKit )化很明显,比如,本节介绍方法 SwiftUI 4.0 已经失效方法二:Runloop我第一次接触 Runloop 是在学习 Combine... SwiftUI ,子视图可以通过 preference 视图修饰器向祖先视图传递信息( PreferenceKey )。

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

GeometryReader :好东西还是坏东西?

GeometryReader 自 SwiftUI 诞生之初就存在,它在许多场景扮演着重要角色。然而,从一开始就有开发者对持负面态度,认为应尽量避免使用。...由于 GeometryReader ideal size 为 (10,10),因此,滚动方向上,返回给 ScrollView 需求尺寸即为 10。...请阅读 用 SwiftUI 方式进行布局[9] 和 SwiftUI 实现视图居中若干种方法[10] 两篇文章,以了解面对同一个需求,SwiftUI 有多种布局手段。...里子和面子:不同尺寸数据 SwiftUI ,有一些 modifier 是布局之后,渲染层面对视图进行调整。... SwiftUI 布局 —— 尺寸( 下 )[11] 一文,我们探讨过有关尺寸“里子和面子”问题。

45870

SwiftUI 视图生命周期研究

不少 SwiftUI 开发者都碰到过视图生命周期行为超出预期状况(例如视图多次构造、onAppear 无从控制等)。...通常情况下,SwiftUI 需要渲染屏幕某个区域或需要该区域数据配合布局时,会在视图值树上创建对应视图。当不再需要参与布局或渲染时视图将被销毁。...ScrollView + VStack ,即使 Cell 视图没有显示屏幕,仍会触发 onAppear ScrollView { VStack { ForEach(0..<100...•ScrollView + VStack ,即使 Cell 视图没有出现在可见区域,但它在最开始就会参与容器布局,因此会在创建初始便触发 onAppear,但无论如何滚动,所有的 Cell 视图始终会参与布局...这在相当程度上改善了因多次创建实例而引发效率问题。 让复杂任务仅执行一次 但是,onAppear 或 task 也并非只会执行一次,如何保证让某些负担较重任务只页面执行一次呢?

4.3K30

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

NavigationView + NavigationLink 界面跳转,苹果给 SwiftUI 使用例子中就是这样写,当然我们正常使用这样写也没啥问题,那我们界面跳转问题是什么呢?...如果你看了我们 Demo代码,你就知道我们是采用 TabView 嵌套 NavigationView 形式,在这样模式下似乎是存在问题 TabView+NavigationView 你利用...有一个还得说明一下,GeometryReader 改变了它显示内容方式。 iOS 13.5 ,内容放置方式为 .center。 iOS 14.0 则为:.topLeading。...3、再提一点关于上面说滚动视图,UIKit我们可以用UICollectionView搞定一切,但是SwiftUI没有这个控件,我建议采用方式是 ScrollView + HStack + VStack...方式去实现,很多同行有说目前来看SwiftUIList在数据量大情况下性能不是特别好,采用ScrollView是个不错方式,而且也很容易构建出来,并不是说每一个Item位置都需要你去计算,

11.8K20

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

Swiftcord[12] 代码展示了如何SwiftUI 下实现倒置列表。阅读 优化 SwiftUI List 显示大数据集响应效率[13] 一文,了解苹果工程师推荐方法。...目前 SwiftUI 没有 API 可以限制用户字段输入字符。很希望苹果能够继续扩展基于 FormatStyle 解决方案,让可以实时对输入内容进行校验。...连锁动画Q: SwiftUI 如何实现连锁动画?例如,我想先给一个视图做动画,当动画完成后立即启动另一个动画。A:不幸是,目前不可能实现连锁动画。...Q&A ( 集锦 - 简体中文 )下文中问题来自开发者与苹果工程师【 集锦 - 简体中文 】频道进行中文讨论( 没有出现在英文 SwiftUI 频道 )。我直接对进行了复制粘贴。... SwiftUI ,有一个从第一版开始就存在但尚未公开SwiftUI 实现滚动容器 —— _ScrollView

14.7K30

SwiftUI 方式进行布局

ScrollView 会使用父视图给定全部建议尺寸创建滚动区域,但在询问子视图需求尺寸时只会提供理想尺寸。...这意味着, ScrollView ,子视图最好明确设定尺寸( 提出明确地需求尺寸 )。因此,在上面的代码,需要通过屏幕高度和视图一高度差来计算上方空白站位视图高度。...scrollDisabled( 则让我们可以 iOS 16+ 屏蔽 ScrollView 滚动手势 )。...五、LayoutPriority SwiftUI ,设置视图优先级( 使用 layoutPriority )是一个好用但并不常用功能。...有关转场动画更多内容,请参阅 SwiftUI 动画机制[8] 一文 八、Layout 协议 4.0 版本SwiftUI 增加了 Layout 协议,通过该协议,开发者可以针对特定场景,创建自定义布局容器

3.2K00

SwiftUI 方式进行布局

ScrollView 会使用父视图给定全部建议尺寸创建滚动区域,但在询问子视图需求尺寸时只会提供理想尺寸。...这意味着, ScrollView ,子视图最好明确设定尺寸( 提出明确地需求尺寸 )。因此,在上面的代码,需要通过屏幕高度和视图一高度差来计算上方空白站位视图高度。...scrollDisabled( 则让我们可以 iOS 16+ 屏蔽 ScrollView 滚动手势 )。...五、LayoutPriority SwiftUI ,设置视图优先级( 使用 layoutPriority )是一个好用但并不常用功能。...有关转场动画更多内容,请参阅 SwiftUI 动画机制 一文 八、Layout 协议 4.0 版本SwiftUI 增加了 Layout 协议,通过该协议,开发者可以针对特定场景,创建自定义布局容器

4.7K80

React-native踩坑小记

tab切换最外层,每一个tab页签对应一个listview,同时listview还嵌套了一个轮播图swiper 开发过程遇到了如下几个问题(android环境下): swiper插件无法显示;...listview没有弹性边界,无法实现线上下拉刷新效果; swiper插件和tab-view插件手势冲突; 如何填平这几个坑: 1....listview没有弹性边界,无法实现线上下拉刷新效果: 因为android本身就没有滚动到边界还能继续滚动策略。。这里使用一些java补丁代码(列表插件所提供),来实现弹性边界-。- 3....React-native,View组件有如下几个常用事件: 争权几个事件(通过返回值来确定这次操作应该由谁来响应) onStartShouldSetResponder onMoveShouldSetResponder...Touch* 组件有两个事件是这里我们需要用到:onPressIn和onPressOut 这两个事件会在手指按下和抬起时触发; 所以我们需要做就是在这两个事件触发锁定和解锁外层scrollview

4.4K80

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

但是,SwiftUI 一些系统控件并没有完全遵循响应式设计原则,由此某些情况下会出现严重错误,影响用户体验,并使开发者无所适从。...原文发表博客 肘子Swift记事本视图变化在前、状态变化在后 SwiftUI ,某些可编程控件执行一定操作时,会先更新视图,待视图变化完成后再修改与其对应状态。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死这是一个 SwiftUI 所有版本存在错误,你可以众多论坛或聊天室里看到不少开发者都在寻找解决方法。...为了改善 AttributeGraph 效率并减少占用空间,SwiftUI 会在一些特定情况下对进行清理和维护(例如通过 CFRunLoopObserverCreate 监听 Runtime 空闲时机...随着版本提高,SwiftUI 功能也确实得到了相当程度增加。不过,即使最新版本一些对 UIKit(AppKit)进行二次包装控件,仍有不少细节处理不到位问题。

589110

掌握 SwiftUI Safe Area

UIKit ,开发者需要利用 safeAreaInsets 或 safeAreaLayoutGuide ,才能确保将视图放置界面可见部分。 SwiftUI 对上述过程进行了彻底简化。...本文将探讨如何SwiftUI 获取 SafeAreaInsets、将视图绘制到安全区域之外、修改视图安全区域等内容。... SwiftUI ,开发者通常只有需要获取 StatusBar + NavBar 高度或 HomeIndeicator + TabBar 高度时才会使用到 safeAreaInsets 。...使用 safeAreaInset 扩展安全区域 SwiftUI ,所有基于 UIScrollView 组件(ScrollView、List、Form),默认情况下都会充满整个屏幕,但仍可确保我们可以安全区域内看到所有的内容...SwiftUI ,有不少功能都属于看一眼就会,但用起来就废情况。

7.5K31

WWDC 23 ,SwiftUI 5 和 SwiftData 初印象

苹果不仅带来了全新形态硬件产品,还推出了几个相当震撼新框架。本文将聊聊我对本届 WWDC SwiftUI 5.0 和 SwiftData 初步印象。...大幅改善了 ScrollView 控制力 本次升级,为 ScrollView 带来了新动态滚动定位系统( 不依赖 ScrollViewReader 和显式 id 声明)、一次性定位系统( 视图进入后...不过极为遗憾是,苹果并没有充分利用 Swift @_backDeploy 功能, SwiftUI 5.0 ,仅有极少切不太重要功能或类型实现了低版本适配:topBarLeading: SwiftUI.ToolbarItemPlacement...开心还是无奈 今年 WWDC ,苹果为 SwiftUI 带来了非常大变革,并推出了开发者向往已久 SwiftData。...对于绝大多数开发者来说,一旦能够应用中使用这些新功能,苹果或许又会带来更多新诱惑。SwiftUI 新特性极大拓展了表达能力,但同时也增加了学习曲线,特别是对初学者而言。

1.1K20

肘子 Swift 周报 #036 | WWDC 2024 观后感

苹果在演示展现了对 AI 理解:避免华而不实技术炫耀,重视隐私保护,让 AI 技术自然融入日常操作,并利用设备与用户之间紧密联系,借助更丰富上下文信息,提供更为个性化 AI 体验。...SwiftUI 初次接触 SwiftUI 今年新特性时,我并未感到特别兴奋。然而,做了更多研究后,我意识到此次更新 SwiftUI 发展史上将具有十分重要意义。...从这个版本开始,SwiftUI 开发团队似乎找到了快速发展 SwiftUI 正确路径,探索出了保持声明式框架特性同时,有效提升表现力方法。...在这次更新SwiftUI 团队转变了以往 API 设计策略——过往设计高度封装且调整空间较小,现在则为开发者提供了更多底层控制能力。...最后 我对 WWDC 2024 满意程度无疑非常高,这种满意是随着我对新功能和新特性逐步了解与深入体验而逐渐增强。这种情况最近几届 WWDC 相对罕见。

7410

WWDC 23 ,SwiftUI 5 和 SwiftData 初印象

苹果不仅带来了全新形态硬件产品,还推出了几个相当震撼新框架。本文将聊聊我对本届 WWDC SwiftUI 5.0 和 SwiftData 初步印象。...大幅改善了 ScrollView 控制力 本次升级,为 ScrollView 带来了新动态滚动定位系统( 不依赖 ScrollViewReader 和显式 id 声明)、一次性定位系统( 视图进入后...不过极为遗憾是,苹果并没有充分利用 Swift @_backDeploy 功能, SwiftUI 5.0 ,仅有极少切不太重要功能或类型实现了低版本适配:topBarLeading: SwiftUI.ToolbarItemPlacement...开心还是无奈 今年 WWDC ,苹果为 SwiftUI 带来了非常大变革,并推出了开发者向往已久 SwiftData。...对于绝大多数开发者来说,一旦能够应用中使用这些新功能,苹果或许又会带来更多新诱惑。SwiftUI 新特性极大拓展了表达能力,但同时也增加了学习曲线,特别是对初学者而言。

35010

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

但是,SwiftUI 一些系统控件并没有完全遵循响应式设计原则,由此某些情况下会出现严重错误,影响用户体验,并使开发者无所适从。...视图变化在前、状态变化在后 SwiftUI ,某些可编程控件执行一定操作时,会先更新视图,待视图变化完成后再修改与其对应状态。这些控件基本上都是对 UIkit(AppKit)二次包装。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死 这是一个 SwiftUI 所有版本存在错误,你可以众多论坛或聊天室里看到不少开发者都在寻找解决方法。...为了改善 AttributeGraph 效率并减少占用空间,SwiftUI 会在一些特定情况下对进行清理和维护(例如通过 CFRunLoopObserverCreate 监听 Runtime 空闲时机...随着版本提高,SwiftUI 功能也确实得到了相当程度增加。不过,即使最新版本一些对 UIKit(AppKit)进行二次包装控件,仍有不少细节处理不到位问题。

26720

如何SwiftUI 创建条形图

前言 条形图以矩形条形式呈现数据类别,宽度和高度与它们表示值成比例。本文将展示如何创建一个垂直条形图,其中矩形高度将代表每个类别的值。...系列文章 如何SwiftUI 创建条形图 SwiftUI 水平条形图 iOS 16 中用 SwiftUI Charts 创建一个折线图 iOS16 中用 SwiftUI 图表定制一个线图... Swift 图表中使用 Foudation 库测量类型 开始图表布局 SwiftUI 对探索不同布局和预览实时视图结果是很友好。...SwiftUI 组合矩形来创建条形图是比较容易。...SwiftUI 是一个很好平台,用于创建视图和快速重构独立子视图。 SwiftUI 构建条形图需要做一些工作,随着使用数据来试用条形图,可以确定更多定制化。

5.1K10

IOS5开发-UIScrollView添加单击事件方法

UIScrollView开发是一个非常常用控件,UIScrollView具有水平、垂直滚动和缩放效果。但是尽然没有响应单击事件这个事件。而这个事件日常交互是非常需要。...比如当用于单击或轻触图片某个位置时,给于一些交互性提示。 下面我将用例子说明一下如何给UIScrollView添加一个单击响应。...但是这样写法经过测试IOS5.0以前版本可以。但IOS5以后(包括5)这不能往下传递,这里我也不知道为什么。希望有知道朋友说一下。...{     NSLog(@"scrollView  touch ended");      } 功能完成,记得ViewController.h上加上UIScrollViewTouchesDelegate...本来我想用UITapGestureRecognizer来实现,但是直接引发异常。不明白为什么UITapGestureRecognizer不能注册UIScrollViews上。

1.8K70
领券