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

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

这些控件基本上都是对 UIkit(AppKit)的二次包装。Sheet执行下面的代码,你可以清楚地看到,在通过手势取消 Sheet 时,与其关联的状态是在 Sheet 完成取消动画后才发生了改变。...而通过调用环境值或直接修改绑定状态,SwiftUI 则遵循了响应式编程原则,进行了的先调整状态,后更新视图的操作。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛或聊天室里看到不少的开发者都在寻找解决方法。...幸运的是,我从 @KyleSwifter 的 解密 SwiftUI 背后的 AttributeGraph 一文中找到了线索。...随着版本的提高,SwiftUI 的功能也确实得到了相当程度的增加。不过,即使在最新的版本中,在一些对 UIKit(AppKit)进行二次包装的控件中,仍有不少细节处理不到位的问题。

759110

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

视图变化在前、状态变化在后 在 SwiftUI 中,某些可编程控件在执行一定的操作时,会先更新视图,待视图变化完成后再修改与其对应的状态。这些控件基本上都是对 UIkit(AppKit)的二次包装。...而通过调用环境值或直接修改绑定状态,SwiftUI 则遵循了响应式编程原则,进行了的先调整状态,后更新视图的操作。...通过手势取消 Sheet 后,快速右滑导航容器会导致应用锁死 这是一个在 SwiftUI 所有版本中存在的错误,你可以在众多的论坛或聊天室里看到不少的开发者都在寻找解决方法。...幸运的是,我从 @KyleSwifter[4] 的 解密 SwiftUI 背后的 AttributeGraph[5] 一文中找到了线索。...随着版本的提高,SwiftUI 的功能也确实得到了相当程度的增加。不过,即使在最新的版本中,在一些对 UIKit(AppKit)进行二次包装的控件中,仍有不少细节处理不到位的问题。

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

    SwiftUI TextField 进阶 —— 事件、焦点、键盘

    ,控制台输出为 textfield in form commit2textfield in form commit1textfield in group committext1 commit 请注意,调用的顺序是从外层向内的...在 SwiftUI 3.0 中,苹果为开发者提供了一个远好于预期的解决方案,同 onSubmit 类似,可以从更高的视图层次来统一对视图中的 TextField 进行焦点的判断和管理。...,我们可以直接通过 UIkit 提供的方法来取消键盘 UIApplication.shared.sendAction(#selector(UIResponder.resignFirstResponder...将键盘辅助视图集成到 toolbar 的逻辑中也有些令人令人费解。 通过 UIKit 创建 当前阶段,通过 UIKit 来创建键盘辅助视图仍是 SwiftUI 下的最优方案。...相信再有 2-3 年,SwiftUI 的主要控件的原生功能就可以比肩对应的 UIKit 控件了。 关于如何对 TextField 的显示做更多的定制,之后会撰文探讨。 希望本文对你有所帮助。

    13.4K10

    在SwiftUI中使用UIKit视图

    如果你已经对如何使用UIViewRepresentable有所掌握,可以直接从SwiftUI风格化部分阅读 基础 在具体演示包装代码之前,我们先介绍一些与在SwiftUI中使用UIKit视图有关的基础知识...将UIKit视图包装成SwiftUI的视图时,我们需要了解两者生命周期之间的不同,不要强行试图找到完全对应的方法,要从SwiftUI的角度来思考如何调用UIKit视图。...例如,UIKit中我们将一个代理对象附加到Text field视图上,当用户输入时,当用户按下return键时,该代理对象中对应的方法将被调用。...在协调器中,我们可以通过双向绑定(Binding),通知中心(notificationCenter)或其他例如Redux模式的单项数据流等方式,将UIKit视图内部的状态报告给SwiftUI框架或其他需要的模块...对于一些实现复杂功能的UIKit模组,如果完全按照SwiftUI的模式将其业务逻辑彻底剥离是非常困难的。因此将无法剥离的业务逻辑的实现代码放入协调器中,靠近代理方法,便于相互之间的协调和管理。

    8.3K22

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

    这包括一个播放按钮、一个静音按钮和用于前进和后退的 15 秒跳过按钮。 2. Adding Remote Playback 那很容易,对吧? 如何从远程 URL 添加视频播放? 那一定要难很多!...问题是你不能直接在 SwiftUI 中使用这个层。 毕竟 SwiftUI 没有 CALayer的概念。 为此,您需要回到 UIKit。...你需要实现它的方法来完成 UIKit 和 SwiftUI 之间的桥梁。...其次,您需要创建一种从 LoopingPlayerView 调用这些方法的方法。...您会在左上角看到画中画按钮……否则不会! 缺点是,在撰写本文时,iOS 14.5是可用的最新版本,VideoPlayer 的 SwiftUI 视图未显示画中画按钮。

    7K10

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

    开始 首先看下主要内容: 在本教程中,您将了解如何在SwiftUI和Combine中使用VIPER体系结构模式,同时构建一个允许用户创建公路旅行的iOS应用程序,来自翻译。...SwiftUI有自己独特的做事方式。如果你将VIPER职责映射到域对象将会不同,如果你将它与UIKit应用的教程相比较。 1....Creating a View with a Presenter 从SwiftUI视图模板中创建一个新文件,并将其命名为TripListView.swift。...当将用户操作发送回数据模型时,VIPER模式甚至更有用。 为此,您将添加一个按钮来创建一个新的旅程。...router处理从一个屏幕到另一个屏幕的转换,设置下一个视图所需的类。 在命令式UI范例中——换句话说,在UIKit中——路由router将负责显示视图控制器或激活segue。

    17.6K10

    自定义 Button 的外观和交互行为

    相较于 UIKit ,SwiftUI 通过 Button 视图,让开发者以少量的代码便可完成按钮的创建工作。...label:目标按钮的当前视图,通常对应着 Button 视图中的 label 参数内容role:iOS 15 后新增的参数,用于标识按钮的角色( 取消或具备破坏性)isPressed:当前按钮的按压状态...而 TapGesture 在不松开手指的情况下,如果移动到可点击区域外,SwiftUI 将不会调用 onEnded 闭包中的操作。...默认情况下,即使单元格的视图中包含了多个按钮,SwiftUI 也只会将 List 的单元格视作一个按钮( 点击后同时调用所有按钮的操作 )。...不再调用其指定的闭包操作,附加手势需在 Button 之外添加( 例如下文的 simultaneousGesture 实现 )为按钮添加 Trigger在 SwiftUI 中,为了判断某个按钮是否被按下

    3.7K60

    SwiftUI - 百行代码变十行,Swift再创辉煌

    而对于开发者来说,新发布的 SwiftUI 可能是最吸引人的特性,在 苹果公司软件工程高级副总裁Craig Federighi的演示中,我们可以轻松地把一百行的前端代码缩减到十几行。...// 为什么需要 SwiftUI // 下面是来自王巍对UIKit的诟病 UIKit 提供的是一套符合直觉的,基于控制流的命令式的编程方式。...不过,不管是从使用的便利性还是稳定性来说,UIKit 都面临着巨大的挑战。我个人勉强也能算是 iOS开发的“老司机”了,但是掉到 UIKit 的坑里这件事,也几乎还是我每天的日常。...当在设计工具中工作时,所编辑的内容会立刻反映到代码上,如果从模拟器切换到手机,手机也能立马看到预览效果。 ?...简便的动画创建方式 创建平滑的动画就像添加一个方法调用一样简单。SwiftUI在需要时自动计算和动画转换。

    3K40

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

    如果你看了我们 Demo中的代码,你就知道我们是采用 TabView 嵌套 NavigationView 的形式,在这样的模式下似乎是存在问题的, 在 TabView+NavigationView 中你利用...和我们UIKit中的效果一样。...3、再提一点关于上面说的滚动视图,在UIKit中我们可以用UICollectionView搞定一切,但是在SwiftUI中没有这个控件,我建议采用的方式是 ScrollView + HStack + VStack...区别于我们UIKit的创建方式,SwiftUI对它进行了简化,具体的创建如下: /// SwiftUI对定时器的简化,可以进去看看具体参数的定义 private let timer = Timer.publish...= .zero /// 当前显示的位置索引, /// 这是实际数据中的1就是数据没有被处理之前的0位置的图片 /// 所以这里默认从1开始 @State var currentIndex

    12.2K20

    SheetKit——SwiftUI模态视图扩展库

    开发SheetKit的主要原因: •便于Deep link的调用SwiftUI提供了onOpenURL方法让应用程序可以非常轻松的响应Deep Link。但在实际使用中,情况并不如预期。...主要因为SwiftUI中重要的视图展示模式:NavigationView、Sheet等都没有迅捷、简便的重置能力。很难通过一两句代码将应用程序立即设置成我们想要的视图状态。...因此,在此种情况下,通常我们会将所有的模态视图集中管理起来,统一调用。请参阅我之前的文章——在SwiftUI中,根据需求弹出不同的Sheet[3]。...•新的半高模态视图在WWDC 2021中,苹果为大家带来了期待已久的半高模态视图。或许推出的比较仓促,这种很受欢迎的交互方式并没有提供SwiftUI版本,仅支持UIKit。...interactiveDismissDisabled SwiftUI 3.0的interactiveDismissDisabled加强版,在通过代码控制是否允许手势取消的基础上,增加了当用户使用手势取消时可以获得通知的能力

    2.9K20

    TCA - SwiftUI 的救星?(一)

    它不仅有更加合理的异步方法和全新特性,更是修正了诸多顽疾。可以说,从 iOS 14 开始,SwiftUI 才算逐渐进入了可用的状态。...而最近随着公司的项目彻底抛弃 iOS 13,我也终于可以更多地正式在工作中用上 SwiftUI 了。 Apple 并没有像在 UIKit 中贯彻 MVC 那样,为 SwiftUI ”钦定“ 一个架构。...SwiftUI 最基础的状态管理模式,做到了 single source of truth:所有的 view 都是由状态导出的,但是它同时也存在了很多不足。...我们真的需要一种架构,来让 SwiftUI 的使用更加轻松一些。 从 Elm 获得的启示 我估摸着前端开发的圈子一年能大约能诞生 500 多种架构[8]。...为 Counter 补全所有测试 现在测试中只包含了 .increment 的情况。请添加减号和重置按钮的相关测试。

    3.3K30

    肘子的 Swift 周报 #052| 回顾初心,写在周报创刊一周年

    在这篇文章中,Jakob Jelling 详细讲述了 Antoine 如何从 2015 年开始,通过持续创作和发展,最终将 SwiftLee 成长为每月拥有 14 万访问者的知名博客。...在本文中,Bas Thomas Broek 深入探讨了如何优化应用的辅助功能,特别针对 VoiceOver 和 Voice Control 两种模式,分析了两者之间的优化方法与权衡之道。...Danny Bolero[18] 虽然 SwiftUI 已推出多年,但在苹果开发生态中,它的使用率仍落后于 UIKit。...在这篇文章中,Danny Bolella 通过分析 Translation[19] 这一只能在 SwiftUI 中使用的新框架,探讨了苹果在 UIKit 和 SwiftUI 之间的取舍。...SwiftUI 环境机制 (SwiftUI Environment)[20] Natalia Panferova[21] SwiftUI 中的环境(Environment)是一种在视图层次结构中跨越多个视图传递数据和配置信息的机制

    3600

    干货 | 关于SwiftUI,看这一篇就够了

    SwiftUI是一种新颖的构建UI方式和全新的编码风格,本文以通俗易懂的语言,从Swift 5.1语法新特性和SwiftUI的优势方面进行分享,希望对热爱移动端的同学有一定的帮助,让大家尽可能快速、全面和透彻地理解...本文主要从以下三个方面讲述SwiftUI的特性: 从代码层面理解Swift 5.1新语法的底层实现; 从数据流方面阐述SwiftUI的黑魔法; 从布局原理层面阐述SwiftUI组件化的优势; 二、...通过简单的几行代码,设置了按钮的点击事件,样式和文案。...通过该结构发现,与UIKit的布局结构有很大的不同,像按钮的一些属性background、padding、cornerRadius等不应该出现在视图主结构中,应该出现在Button视图的结构中。...同时SwiftUI中也是支持frame设定,但也不会像UIKit中那样作用于当前元素,在内部也是形成一个虚拟的View来承载frame设定,在布局过程中进行frame计算最终显示出想要的结果。

    10.5K11

    SwiftUI - 百行代码变十行,Swift再创辉煌

    而对于开发者来说,新发布的 SwiftUI 可能是最吸引人的特性,在 苹果公司软件工程高级副总裁Craig Federighi的演示中,我们可以轻松地把一百行的前端代码缩减到十几行。...为什么需要 SwiftUI 下面是来自王巍对UIKit的诟病 UIKit 提供的是一套符合直觉的,基于控制流的命令式的编程方式。...不过,不管是从使用的便利性还是稳定性来说,UIKit 都面临着巨大的挑战。我个人勉强也能算是 iOS开发的“老司机”了,但是掉到 UIKit 的坑里这件事,也几乎还是我每天的日常。...当在设计工具中工作时,所编辑的内容会立刻反映到代码上,如果从模拟器切换到手机,手机也能立马看到预览效果。...创建平滑的动画就像添加一个方法调用一样简单。

    2.3K30

    肘子的 Swift 周报 #033|改善社区活跃度,仅更新论坛还不够

    在这篇文章中,我将梳理从首个版本起那些给我留下深刻印象的 SwiftUI 关键更新及其影响。这不仅是对 SwiftUI 从诞生到逐渐成熟过程的回顾,也是一次对它所蕴含活力的新的认识。...在这篇文章中,Antoine van der Lee 探讨了如何以适合 SwiftUI 的方式实施 MVVM 架构模式来构建视图。...Avoid These Common Errors When Switching from UIKit to SwiftUI ( 从 UIKit 切换到 SwiftUI 时应避免的常见错误 )[16]...Jeremy Gale[17] Jeremy Gale 在这篇文章中探讨了 UIKit 开发者在学习 SwiftUI 时面临的独特挑战。...文章详细分析了从 UIKit 转向 SwiftUI 时常见的误区,并通过具体的代码重构示例展示了如何提升 SwiftUI 代码的可读性和维护性。

    14510

    探索 App Clips

    ◆ ◆  ◆ 开发 App Clips从iOS14开始支持,所以可以直接用SwiftUI进行开发,这也是苹果所推荐的开发形式。...从外部调起的时候就会传入一个URL过来,App Clips进行解析以调起对应的页面。 有一点需要了解的是,在WWDC2020中,苹果演示的是一个类似于微信小程序二维码那样的异形码。...因为App Clips是从iOS14推出的,而SwiftUI是从iOS13推出的,所以我们可以选择使用SwiftUI进行开发,这也是苹果推荐的开发方案,当然也可以选择UIKit的方式。...◆ ◆  ◆ 客户端代码 客户端进行开发时,无论采用UIKit还是SwiftUI,都是通过NSUserActivity对App Clips传入的URL做解析处理,并根据URL处理不同的业务逻辑,这块和 ...对于URL的处理,使用UIKit和SwiftUI的处理方式不同,如果是UIKit则采用下面的方法处理URL传参。 UIKit通过UIScene的代理方法接收回调,例如下面的方式。

    1.9K20

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

    本文将介绍几种在 SwiftUI 中获取当前滚动状态的方法,每种方法都有各自的优势和局限性。...: UIScrollView, willDecelerate decelerate: Bool)手指拖动结束后( 手指离开时 ),调用此方法在 SwiftUI 中,很多的视图控件是对 UIKit( AppKit...目前 SwiftUI 在内部的实现上去 UIKit( AppKit )化很明显,比如,本节介绍的方法在 SwiftUI 4.0 中已经失效方法二:Runloop我第一次接触 Runloop 是在学习 Combine...模式,因此无法有效地区分滚动是由那个控件造成的方法三:PreferenceKey在 SwiftUI 中,子视图可以通过 preference 视图修饰器向其祖先视图传递信息( PreferenceKey...待 SwiftUI 更多的底层实现不再依赖 UIKit( AppKit )之时,才会是它 API 的爆发期。希望本文能够对你有所帮助。

    3.8K40

    在Android应用中实现跳转的计数和模式切换按钮

    问题描述 在程序应用中,我尝试引入了两个新功能:连续点击跳转UI和切换按钮名称模块显示。...用户在使用过程中遇到了以下问题: 连续点击跳转UI问题:首次连续点击八次能成功跳转UI,但在第二次尝试时无法跳转。 按钮创建问题:应用在每次操作时创建两个按钮,这种方法在视觉上和性能上都不够高效率。...第二个问题的解决方案:控制按钮可见性 为了解决按钮创建问题,在同一个活动中控制两个按钮的可见性,而不是重复创建按钮: 用户可以通过点击“切换升级模式”按钮进入"升级模式"。...用户再次点击“退出升级模式”按钮返回到"蓝牙模式"。 通过这种方式,提升了用户界面的体验。 结论 通过上述解决方案,解决了用户在操作上的不便,提升了应用的整体性能,还可以优化UI的便捷性。...谢谢大家的阅读: )

    26440
    领券