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

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

众所周知,SwiftUI 是一个响应式框架,这意味着,当数据源发生变化时,框架会自动更新视图。同样,当我们想调整视图显示,应直接对状态进行修改。...但是,SwiftUI 一些系统控件并没有完全遵循响应式设计原则,由此某些情况下会出现严重错误,影响用户体验,并使开发者无所适从。...原文发表博客 肘子Swift记事本视图变化在前、状态变化在后 SwiftUI ,某些可编程控件执行一定操作,会先更新视图,待视图变化完成后再修改与其对应状态。...它复现条件如下:iOS 16 系统,真机或模拟器上测试点击视图列表按钮,可以进入下一级视图。...随着版本提高,SwiftUI 功能也确实得到了相当程度增加。不过,即使最新版本一些对 UIKit(AppKit)进行二次包装控件,仍有不少细节处理不到位问题。

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

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

众所周知,SwiftUI 是一个响应式框架,这意味着,当数据源发生变化时,框架会自动更新视图。同样,当我们想调整视图显示,应直接对状态进行修改。...但是,SwiftUI 一些系统控件并没有完全遵循响应式设计原则,由此某些情况下会出现严重错误,影响用户体验,并使开发者无所适从。...视图变化在前、状态变化在后 SwiftUI ,某些可编程控件执行一定操作,会先更新视图,待视图变化完成后再修改与其对应状态。这些控件基本上都是对 UIkit(AppKit)二次包装。...它复现条件如下: iOS 16 系统,真机或模拟器上测试 点击视图列表按钮,可以进入下一级视图。...随着版本提高,SwiftUI 功能也确实得到了相当程度增加。不过,即使最新版本一些对 UIKit(AppKit)进行二次包装控件,仍有不少细节处理不到位问题。

25720

SwiftUI 创建自适应程序化导航方案

因此 SwiftUI ,掌握两种导航容器状态表述差异是实现自适应导航方案关键。...需要特别注意是, NavigationStack ,根视图是直接通过代码声明,并不存在于“栈”。...不过仅有在前两列通过 List(selection:) 来修改状态,才能在自动转换 NavigationStack 表现形式具备程序化导航能力。方案一对此有进一步说明。...不要忘记 NavigationStack 根视图不在它“栈”数据本例,转换至 NavigationStack ,需要将 Detail 列声明视图添加到“栈”底端。反过来则将其移除。...每周也会对当周博客上新文章以及 Twitter 上发布 Tips 进行汇总,并通过邮件列表形式发送给订阅者。订阅下方 邮件列表[8],可以及时获得每周 Tips 汇总。

4.2K30

SwiftUI-数据流

数据处理基本原则 Data Access as a Dependency: SwiftUI 数据一旦被使用就会成为视图依赖,也就是说当数据发生变化了,视图展示也会跟随变化,不会像 MVC 模式下那样要不停同步数据和视图之间状态变化...A Single Source Of Truth: 保持单一数据源, SwiftUI 不同视图之间如果要访问同样数据,不需要各自持有数据,直接共用一个数据源即可,这样做好处是无需手动处理视图和数据同步...不过值类型传递时会发生复制操作,所以给传递后值类型即使属性更新了也不会触发最初传过来值类型重新赋值,所以界面并不会刷新,此时需要用@Binding,因为它可以将值类型转为引用类型,这样传递...ObservableObject 应用开发过程,很多数据其实并不是 View 内部产生,这些数据有可能是一些本地存储数据,也有可能是网络请求数据,这些数据默认是与 SwiftUI 没有依赖关系...最终再次呈现给用户,等待下次界面操作 注意 SwiftUI ,开发者只需要构建一个视图可依赖数据源,保持数据单向有序流转即可,其他数据和视图状态同步问题 SwiftUI 帮你管理,所以 ViewController

10K20

AVKit框架详细解析(四) —— 基于AVKit 和 AVFoundation框架视频流App构建

这就是应用程序如何用数据填充现有列表方式。 视频本身来自嵌入应用程序包 JSON 文件。 如果您好奇,您可以查看 Video.swift 以了解它们是如何获取。...每当您将其设置为非 nil 值,就会显示全屏封面的内容。...现在,是时候将您视频剪辑列表添加到播放器,以便它可以开始播放它们。...每次收到通知,您都会知道播放器已进入下一个视频。 要在 Swift 中使用 KVO——比 Objective-C 好得多——你需要保留对观察者引用。...缺点是,撰写本文,iOS 14.5是可用最新版本,VideoPlayer SwiftUI 视图未显示画中画按钮。

6.9K10

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

也就是当显示主界面菜单列表视图已经完成了实例创建(可以通过 ListEachRowHasID 构造函数添加打印命令得以证明),因此也不应是实例化列表视图导致延迟。... SwiftUI 视图生命周期研究[3] 一文,我对 List 如何对子视图显示进行优化做了一定介绍。...标识( Identity )是 SwiftUI 程序多次更新识别相同或不同元素手段,是 SwiftUI 理解你 app 关键。...当仅通过 ForEach 来指定显示标识,List 会对这些视图显示进行优化,仅在需要显示才会对其进行实例化。...升降序切换 对数据进行降序显示且仅允许使用者手工滚动列表。系统邮件、备忘录等应用均采用此种方式。

9K20

Django源码学习-8-ListView&DetailView通用视图

Django通用视图可以减少开发单调性,它抽象出一些视图开发中常用代码和模式,这样就可以无需编写大量代码情况下,快速编写出常用视图函数。 ?...pass ① ListView:显示对象列表 用于展示一个 Model 里面的所有对象,也可以是其子集 (queryset) ,支持分页。...(展示 Publisher 所有对象) model = Publisher # 模板 context model 变量名,默认是 object_list context_object_name...② DetailView显示一个对象某个属性详细信息 用于显示某一 Model 一个 object 详细信息。...用属性 model 或 queryset 指定要操作 Model 或 queryset; DetailView 会根据 URLConf 或 筛选出一个

1.4K10

架构之路 (五) —— VIPER架构模式(一)

VIPER架构模式是MVC或MVVM另一种选择。虽然SwiftUI和Combine框架创建了一个强大组合,可以快速构建复杂ui和在应用程序中移动数据,但它们也面临着各自挑战和对架构看法。...路由器Router处理屏幕之间导航。这与SwiftUI不同,SwiftUI,视图显示任何新视图。...本例,主要entity是Trip,它包含一个路点Waypoints列表,路点是旅程各个站点。 这个应用程序包含一个DataModel类,它包含一个旅行列表。...当您将其放置NavigationView,该链接将成为一个按钮,将destination推送到导航堆栈上。 content块可以是任何一个SwiftUI视图。...这需要它自己一组presentation逻辑。您可以使用TripDetailPresenter,或者本例,创建一个单独TripMapViewPresenter。

17.3K10

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

View 添加显式标识符后( 使用 id 修饰器),视图刷新,List 将会为 ForEach 所有视图创建实例( 并非渲染 )用以比对视图类型构造参数是否发生变化,但仍然只会渲染屏幕上显示部分...请阅读 优化 SwiftUI List 显示大数据集响应效率[6] 以及 避免 SwiftUI 视图重复计算[7] 两篇文章,了解更多有关性能优化方面的内容通过 currentPostion 获取需要滚动到...transcription 结果值已经为高亮显示值( 当前选择高亮位置 ),且下一个序号位置仍在同一个 transcription ,那么将放弃滚动。...List ,每个视图进入显示窗口都会调用它 onAppear,每个视图退出显示窗口都会调用它 onDisapper。...了解更多内容,请阅读 SwiftUI 视图生命周期研究[9] 一文优先定位于最靠近屏幕中央搜索结果:/// 从 List 当前显示 transcription 中就近选择 match positionprivate

4.2K30

django 1.8 官方文档翻译: 1-2-4 编写你第一个Django应用,第4部分

本例, request.POST[‘choice’] 返回了所选择投票项目的 ID ,以字符串形式。 request.POST 值永远是字符串形式。... 现在,浏览器访问 /polls/1/ 并完成投票。每次投票后你将会看到结果页数据都有更新。 如果你没有选择投票选项就提交了,将会看到错误信息。...index() 用于显示 polls 列表 index() 视图 (也在教程 第3部分),也是存在类似的问题。...这两个视图分别用于显示两种抽象概念 “显示一系列对象列表” 和 “显示一个特定类型对象详细信息页”。 每个视图都需要知道使用哪个模型数据。因此需要提供将要使用 model 参数。... DetailView poll 变量是自动提供 – 因为我们使用了一个 Django 模型 (Poll) ,Django 能够为上下文变量确定适合名称。

1.4K10

SwiftUI 布局 —— 尺寸( 上 )

SwiftUI ,只有符合 View 协议 component 才能被 ViewBuilder[3] 所处理。因此任何一种布局容器,最终都会被包装并以 View 形式出现在代码。...因此,为了简化文字,我们文章中会将父视图与具备布局能力容器等同起来。 不过需要注意是, SwiftUI ,有一类视图是会在视图树上显示为父视图,但并不具备布局能力。...顾名思义,建议尺寸是父视图为子视图提供建议,子视图计算其需求尺寸是否考虑建议尺寸完全取决于它自己行为设定。...,父视图会根据它需求选择合适建议模式提供给子视图。...;如果建议高度小于单行显示高度,则需求高度返回单行显示高度 20.33;如果建议高度高于单行显示高度且宽度大于单行显示宽度,则需求高度返回单行显示高度 20.33 …… 未指定模式 当两个维度均为未指定模式

4.6K20

Django 1.10文文档-第一个应用Part4-表单和通用视图

这意味着,当有人选择一个单选按钮并提交表单提交,它将发送一个POST数据choice=#,其中# 为选择ChoiceID。...这个函数可以避免视图函数硬编码URL。它需要我们给出想要跳转视图名字和该视图所对应URL模式需要给该视图提供参数。... 现在,浏览器访问/polls/1/然后为Question投票。应该看到一个投票结果页面,并且每次投票后都会更新。 如果提交没有选择任何Choice,应该会看到错误信息。...这里使用两个通用视图:ListView和DetailView。这两个视图分别代表“显示对象列表”和“显示特定类型对象详细信息页面”抽象概念。 每个通用视图需要知道它将作用于哪个模型。...而对于DetailView,question变量会被自动提供,因为我们使用了Django模型(Question),Django会智能选择合适上下文变量。

2.3K40

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

因此,如果你正在创建一个视图来显示可滚动内容,并可能进行选择操作,那么 iOS 和 macOS 上使用 List 将有最好体验。...Table 中上下文菜单Q:如果我 TABLE 上添加了一个上下文菜单,我如何确定哪一行导致了菜单显示(无需选择该行)?...Swiftcord[12] 代码展示了如何在 SwiftUI 下实现倒置列表。阅读 优化 SwiftUI List 显示大数据集响应效率[13] 一文,了解苹果工程师推荐方法。... SwiftUI 4 ,可以使用 .scrollContentBackground(.hidden) 隐藏列表默认背景searchableQ:是否有办法.searchable() 修饰器以编程方式设置搜索字段焦点...Too complex to type checkQ:我 iOS 14 SwiftUI 遇到一个问题,我试图有条件地显示 3 个符合 Shape 协议对象一个。

14.7K30

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

但在开始实现更复杂检查器视图,特别是涉及带有 / 不带步进器或颜色选择多个文本字段,整个运行速度开始剧烈下降。...但每当 SwiftUI 更新检查器视图(这种更新可能出现在移动过程,甚至是输入文本字段时候),渲染速率都会下降到每秒 10 到 15 帧,而且相当不稳定。这显然让人无法容忍。...首先,由可选对象提供视图每次重绘都是完全重新创建。我虽然通过缓存稍稍提升了性能表现,但实际体验仍然非常糟糕。事实证明,SwiftUI 检查器视图就是没法提供合理重绘速度。...但这会导致检查器值出现延迟,因此地图编辑器交互过程(比如使用移动工具)结果不准确,所以效果还是称不上完美。 但我觉得这可能只是个独立问题,并不能因此把 SwiftUI 一棒子打死。...我刚开始以为是因为地图编辑器 SpriteKit 主视图仍在后台渲染。所以我尝试工作表显示出来后禁用渲染,但结果没有任何改变。 变更从一种环境传播至另一环境,我也遇到了类似的延迟问题。

4.8K20

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

是否有任何建议用来检测列表选择,类似于 “NavigationLink”,但不导航到另一个视图(例如,显示 Sheet 或从列表选择一个选项 )?...A:如果在同一个视图中,有多个相互关联 @State 属性,将他们提取到一个结构或许是好选择。将他们提取到 view model 也是一种策略,但不是必须。...假设我们想创建一个类似于 iMessage 视图,在那里你可以看到一个信息列表(与本例无关),视图底部有一个文本框。当用户点击文本字段,键盘会在其工具栏中出现一个文本字段。...锁定 Charts 纵轴刻度Q:我有一个 Swift 图表,通过监听拖动事件实现在拖动过程显示一个 RuleMark。拖动过程,Y 轴刻度会变大。...例子,不拖动从 0 到 75,拖动从 0 到 100。有什么办法可以阻止这种情况吗?A:你可以用 .chartYScale(domain: 0 ... 75) 锁定 Y 轴刻度域。

12.2K20

django 1.8 官方文档翻译: 3-4-2 内建显示视图

对象通用视图 TemplateView确实很有用,但是当你需要 呈现你数据库内容Django通用视图才真的会脱颖而出。...注意 所以,当(例如)DjangoTemplates后端APP_DIRS选项TEMPLATES设置为True,模板位置应该为:/path/to/project/books/templates...编写“友好”模板上下文 你可能已经注意到了,我们publisher列表例子把所有的publisher对象 放到 object_list 变量。...当你处理 一个object或者queryset,Django能够使用你定义对象显示自述名(verbose name,或者复数自述名,对于对象列表)来填充上下文(context)。...我们可能想要对图书列表按照出版日期进行排序来选择一个简单例子,并且把 最近放到前面: from django.views.generic import ListView from books.models

1.4K40

SwiftUI 实现一个开源 App Store

App Store 迭代,排行榜(Top Charts)一直是一个主要入口,新用户基本都会从榜单下载 App,所以,榜单重要性不容忽视。...比如更新(Updates) 标签功能单一,就是负责显示需要更新 App 列表。...[iAppStore-04.jpg] 最重要是,我们把所有国家和地区商店,都集成一个面板,通过下拉列表选择,实现快速切换榜单。...切换图标可以选择自己显示图标等。 [iAppStore-08.jpg] 大家想要什么功能,可以评论区留言啊~ 三、调研工作 接下来,我们说一下要实现以上功能,需要 API 怎么调研出来!...比如,SwiftUI 还不支持 WebView,所以用 SFSafariViewController 桥接 View SwiftUI 组件显示会异常。

2K20
领券