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

使用 SwiftUI 创建一个灵活选择器

前言 最近,在我正在开发一个在 Dribbble 上找到设计 SwiftUI 实现时,我想到了一个点子,可以通过一些酷炫筛选器扩展该项目以缩小结果列表。...在使用 UIKit 时,我总是将这种类型视图实现为具有特定 UICollectionViewFlowLayout UICollectionView。但在 SwiftUI 中该如何实现呢?...Identifiable 和 Hashable 协议确保我们可以轻松创建具有 ForEach 循环 SwiftUI 视图。...该函数只需切换特定数据 isSelected 属性。...然后,详细介绍了实现该选择器逻辑,包括如何处理选项布局、宽度和高度,以及如何处理用户与按钮交互。 最后,提供了一个简单视图实现,可以在 SwiftUI 中使用该选择器。

24420

如何结合 Core Data 和 SwiftUI

从那里开始,我们可以像常规 Swift 数组一样开始使用学生,但是您会发现有一个陷阱。...您可以根据需要运行代码,但没有太多意义——该列表将为空,因为我们尚未添加任何数据,因此我们数据库为空。...为了解决这个问题,我们将在列表下方创建一个按钮,每次点击都会添加一个新随机学生,但是首先我们需要一个新属性来存储托管对象上下文。 让我重申一下,因为这很重要。...// more code to come } **注意:**不可避免地有人会抱怨我强行对randomElement()调用,但是实际上我们只是手工创建了具有数组——它将永远成功。...self.moc.save() 最后,您现在应该可以运行该应用程序并对其进行尝试——单击几次 “Add” 按钮以生成一些随机学生,您应该看到他们滑入我们列表某个位置。

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

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

VIPER为这种情况提供了一种替代方案,可以与SwiftUI和Combine结合使用,帮助构建具有清晰架构应用程序,该架构有效地分离了所需不同功能和职责,如用户界面、业务逻辑、数据存储和网络。...添加一个新变量到类: @Published var trips: [Trip] = [] 这是用户将在视图中看到旅行列表。...点击+按钮将向列表添加一个New Trip。 4. Deleting a Trip 创建旅行用户可能还希望能够删除它们,以防出错或旅行结束。既然已经创建了数据路径,向屏幕添加额外操作就很简单了。...然后将directions复制到routes数组。 要使用presenter,创建一个名为TripMapView.swiftSwiftUI View。...使用presenter向列表添加新路径点add按钮。 一个列表List,它使用ForEach与presenter为每个路点创建一个单元格。

17.4K10

SwiftUI 之 HStack 和 VStack 切换

想了解更多信息,可以查看我文章 - SwiftUI 布局系统第三章 目前,我们按钮是垂直排列,并且填满了水平线上可用空间(你可以用以上示例代码预览按钮样子),虽然这在竖向 iPhone 上看起来很好...虽然我们也有很多方法能解决这些问题(例如使用类似在这篇 Q&A 中用来使多个视图具有相同宽度和高度技术),但真正问题是当我们要动态的确定方向时,测量可用空间是否是一个好方法。...Xcode 14 一部分仍在测试阶段) 其中一个工具是新 Layout 协议,它既能让我们创建完整自定义布局,直接集成到 SwiftUI 布局系统中,同时也提供给我们一种更丝滑更动画方式在各种布局之间动态切换...这样做会令动画更流畅,例如在切换设备方向时,我们也有可能在执行此类更改时获得小幅性能提升(因为 SwiftUI 总是在其视图层次结构为静态时尽可能表现最佳) 选择合适视图 但我们还没有结束,因为...就像字面意思一样,这种新容器将会在我们初始化时传递候选列表中,基于当前上下文挑选出最优视图。

2.8K10

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

本文将通过一个优化列表视图案例,展现在 SwiftUI 中查找问题、解决问题思路,其中也会对 SwiftUI 视图显式标识、@FetchRequest 动态设置、List 运作机制等内容有所涉及...新问题 细心朋友应该可以注意到,运行解决方案一代码后,在第一次点击 bottom 按钮时,大概率会出现延迟情况(并不会立即开始滚动)。...升降序切换 对数据进行降序显示且仅允许使用者手工滚动列表。系统中邮件、备忘录等应用均采用此种方式。...如果必须给用户提供直接访问两端数据方式,动态切换 SortDescriptors 或许是更好选择。...获取若干最新数据,将数据逆向添加入数组列表显示后率先移动到最底端(取消动画) 通过 refreshable 调用下一批数据,并继续逆向添加入数组 用类似的思路,还可以实现向下增量读取或者两端增量读取

9.1K20

SwiftUI数据流之State&Binding

,子视图FilterView中定义了@Binding var showFavorited: Bool引用传入参数 注释4,当切换开关后,由于@Binding机制作用,会修改外层单一数据源(single...,容易产生问题 小结:可以修改flag原因,添加了property wrapper属性,变量本身并没有变化,而是修改了由SwiftUI维护的当前struct之外变量 @State内部实现 为了进一步深入分析...为了分析变量状态,在16行,User结构体init方法;39行,ContentViewinit方法结束;47行,按钮点击执行函数部分,都加入了断点 由于@State针对值类型,为了打印出struct地址...,这里没有全部展示出来; 再点击一次Count+1按钮,count值变为2,user地址将持续保持不变,生命周期与视图保持一致。...View 生命周期保持一致 Binding将存储在别处值语意属性转换为引用语义,在使用时需要在变量名加$符号 添加了property wrapper属性,变量本身并没有变化,而是修改了由SwiftUI

4K30

面向所有人 UI 编程 :透过点按弹窗初尝 SwiftUI

SwiftUI 集众家之长,具有诸多优秀特性,可以预见它将会出现在诸多应用程序中。若你有兴趣,我会在其它文章中详解 SwiftUI,本文只着重讲其中弹窗写法与逻辑。 你会怎样描述一个程序?...其中 View 表示一个视图,比如我们在手机上看到一个滑条,一张图片,一个列表等种种,都叫做视图;而 Modifier 则是修饰器,它作用是为视图增加功能,比如圆角,动画,阴影,边际,背景等等。...而点按菜单,顾名思义,就是一个按钮,那么我们设置一个 Button View。...在按钮中,我们需要设置两个点:按钮动作,也就是 action,里面的两行代码会将名言文字复制到剪贴板;另一个点是下面的 HStack ,表示一个水平排列 View。...因为我写文章时候已经是晚上了,手机自动切换到了夜间模式,我们应用程序也完成了自动切换。这是如何做到呢?我会在其它文章中详细讲解。

2.1K40

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

快速检索数组元素Q:为什么没有简单方法将 TABLE 选择行映射到提供表内容数组元素上?似乎唯一方法是在数组中搜索匹配 id 值,这对于大表来说似乎效率很低。...如何减少主线程负担Q:如何避免所有操作都被放置在主线上?任何标记 @Published 变量都应该在主线上被修改,所以应该使用 @MainActor 。但任何触及该属性代码都将被影响。...Swiftcord[12] 代码展示了如何在 SwiftUI 下实现倒置列表。阅读 优化在 SwiftUI List 中显示大数据集响应效率[13] 一文,了解苹果工程师推荐方法。...将背景扩展到安全区域Q:如果我有一个自定义容器类型,可以接受一个顶部和底部视图,是否有办法让 API 调用者将所提供视图背景扩展到安全区域内,同时将内容( 如文本或按钮 )保留在安全区域内?...Text 与 TextField 在编辑模式下切换Q:在 editMode 文档中建议,在非编辑模式下,可以选择将 Text 视图换成 TextField 。

14.7K30

如何在 SwiftUI 中创建悬浮操作按钮

下面我们就来详细介绍一下还如何实现这个悬浮按钮需求。创建悬浮操作按钮如何 SwiftUI 创建一个类似 Twitter App 中悬浮按钮。...实现悬浮操作按钮可能有很多方法,下面是我要实现按钮一些简单需求,如下:悬浮按钮应该出现在屏幕主要内容前面。悬浮按钮位于屏幕右下角。悬浮按钮具有圆角形状,并在中心具有一个图标。...以下是一个简单列表视图,嵌套在导航视图和选项卡视图中,列表中显示了 item 加索引内容。...将一个按钮放在内容视图上。这将在列表视图上添加一个加号图像按钮。示例运行截图如下:悬浮按钮位于屏幕右下角接着,是需要实现需求中第二步,使按钮与内容视图对齐到右下角。...我们还在按钮周围添加了填充,以使其不会过于靠近边缘。示例运行截图如下:使悬浮按钮呈现圆形接着,是需要实现需求中第三步,使悬浮按钮具有圆角形状,并在中心具有一个图标。

6621

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

、焦点切换、键盘设置等相关经验、技巧和注意事项。...好在,FocusState 不仅支持布尔值,还支持任何哈希类型。我们可以使用符合 Hashable 协议枚举来统一管理视图中多个 TextField 焦点。...在多个 TextFiled 之间切换焦点 通过使用 focused 和 onSubmit 结合,我们可以实现当用户在一个 TextField 中输入完成后(点击return),自动让焦点切换到下一个...另外,有时候为了提高交互体验,我们可以希望用户在录入结束后,无需点击return按键,通过点击屏幕其他区域或者以滚动列表方式来取消键盘。同样也需要使用编程方式让键盘消失。...自定义 SubmitLabel 默认情况下,TextField(SecureField)在键盘上对应 submit 行为按钮为return,通过使用 SwiftUI 3.0 中新增了submitLabel

13.1K10

Swift入门:闭包

Closure 到目前为止,您已经遇到了整数、字符串、双精度数、浮点数、布尔值、数组、字典、结构和类,但是还有另一种类型数据在Swift中广泛使用,它被称为闭包。...这些是复杂,但它们是如此强大和富有表现力,它们在 Cocoa Touch 广泛使用,所以如果你不了解他们,你不会走得很远。 闭包可以看作是保存代码变量。...闭包还捕获了创建它们环境,这意味着它们会复制使用它们环境内部使用值。 下文相当简单。。。...我还是觉得同网站另外两篇更值得学习: 100 Days of SwiftUI —— Day 6:闭包 (上) 100 Days of SwiftUI —— Day 7:闭包 (下) 之所以不翻译剩下原文...本文来自Hacking with Swift 给 swift 初学者入门课程 Swift for Complete Beginners Closures

51510

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

首先,导航到 VideoFeedView.swift 并在 SwiftUI 导入正下方添加以下导入: import AVKit 看看下面这个,你会看到你已经有了一个列表和一个视频数组。...这包括一个播放按钮、一个静音按钮和用于前进和后退 15 秒跳过按钮。 2. Adding Remote Playback 那很容易,对吧? 如何从远程 URL 添加视频播放? 那一定要难很多!...现在,是时候将您视频剪辑列表添加到播放器中,以便它可以开始播放它们。...这会在 2x 和 1x播放速率之间切换。 3) 当有人单击播放器视图时,您可以添加一个侦听器。 这会切换视频静音状态。 注意:确保首先添加双击侦听器,然后单击。...您会在左上角看到画中画按钮……否则不会! 缺点是,在撰写本文时,iOS 14.5是可用最新版本,VideoPlayer SwiftUI 视图未显示画中画按钮

6.9K10

如何从 0 到 1 实现一个支持排序、查找、分页表格组件(React版)

,但通常这些库与你特定案例设计和需求不匹配,并且具有许多你不需要功能,有时,自己动手可能会更好些,以便在功能和设计方面具有完全灵活性。...开始之前,我们在来总结下项目的需求: 支持列表分页 支持字符串、布尔值、数字及日期升序和倒序排列 支持字符串、布尔值、数字和日期数据查询 本案例不会借助其他第三方组库(除了基础React),我们从...,同时我们增加了一个格式化属性,我们可以按照自己需求自定义数据项显示格式(这里我只是处理了布尔自定义格式化,有兴趣的话你可以尝试下日期格式化) 我更喜欢在数组map函数里使用 return,...在这个列表组件里,我们分页将实现这些需求: 显示当前页面 active page,你可以进行页面切换操作 count,用于计算数据总行数 rows per page,设置每页显示几条数据 total...: 接下来我们继续定义分页按钮相关事件,进行页面的切换,同时下面的文本显示当前页面和相关数据,完善后 Pagination.js 示例代码如下: const Pagination = ({

2.5K20

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

是否有任何建议用来检测列表行选择,类似于 “NavigationLink”,但不导航到另一个视图(例如,显示 Sheet 或从列表中选择一个选项 )?...对 iOS 和 iPadOS 来说,一个按钮或许有效,但对 macOS 就不太适合了。另外,.contextAction 支持多选。它还会回来吗?...contextMenu_2022-10-26_14.01.21.2022-10-26 14_02_29如何对 @State 变量进行测试Q:对于测试 SwiftUI 视图中 @State 变量是否有推荐方式...在该枚举类型上切换。...每周也会对当周博客上新文章以及在 Twitter 上发布 Tips 进行汇总,并通过邮件列表形式发送给订阅者。订阅下方 邮件列表[25],可以及时获得每周 Tips 汇总。

12.2K20

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

,并可通过按钮在搜索结果中进行滚动切换?...-08-22_09.16.25.2022-08-22 09_17_38通过按钮实现搜索结果切换image-20220822084740855切换搜索结果时可自动定位到结果所在位置点击非当前高亮关键字...image-20220822161247454点击切换按钮定位到对应搜索结果为 TranscriptionRow 视图添加显式标识符,并通过 ScrollViewProxy 滚动到指定位置。...请阅读 优化在 SwiftUI List 中显示大数据集响应效率[6] 以及 避免 SwiftUI 视图重复计算[7] 两篇文章,了解更多有关性能优化方面的内容通过 currentPostion 获取需要滚动到...每周也会对当周博客上新文章以及在 Twitter 上发布 Tips 进行汇总,并通过邮件列表形式发送给订阅者。订阅 邮件列表[14],可以及时获得每周 Tips 汇总。

4.2K30

SwiftUI:Alert弹窗

如果发生重要事件,通知用户一种常见方法是使用警报Alert弹窗-根据您需要,该弹出窗口包含标题,消息和一个或两个按钮。 但是请考虑一下:何时应该显示警报以及如何显示Alert?...基本SwiftUIAlert具有标题,消息和一个关闭按钮,如下所示: Alert(title: Text("Hello SwiftUI!")...更有趣是我们如何显示警报:我们不将警报分配给变量,然后编写诸如myAlert.show()之类东西,因为这将回到旧“一系列事件”思维方式。...SwiftUI将观察showingAlert,并在它变为true时立即显示警报。...将按钮和他们放在一起,下面是一些示例代码,当点击按钮时会显示警报: struct ContentView: View { @State private var showingAlert = false

5.4K20

【新!超详细】Figma组件属性完全指南

例如,我创建了一个具有三种类型按钮:主要、次要和再次级。每个都有 4 种状态:启用、悬停、聚焦和禁用。此外,每个都有两个图标,一个在左边,一个在右边,加上一个文本标签。...布尔属性 在我看来,这是最强大属性。布尔值是代码中使用术语,表示真或假。使用此属性,您可以隐藏或显示组件中元素。例如,让我们看一个包含图标的按钮。...如果您希望图标出现在按钮内,请将其切换为 ON (true)。如果没有,请将其切换为 OFF(假) 何时使用布尔属性? 布尔属性非常适合显示和隐藏图层。例如,对于带有和不带有图标的按钮。...为了克服它,您可以在布尔属性中写入单词“Icon”之前添加单词“Show”。 一个老派技巧是在其中一个属性中“图标”一词之后添加一个空格。因此,布尔值和交换值将具有相同属性名称。...属性列表 如果您有一个具有布尔值和另一个属性组件,请对属性列表进行排序,布尔值位于顶部,然后是其他属性。当您将布尔切换为关闭时,另一个属性会消失并且列表会移动。

10.9K22

Xcode 13 变化

内置图标.jpg 项目文件图标.jpg 新建 SwiftUI 项目工程中不再有 Info.plist 文件,新建 iOS 项目工程中 Info.plist 文件中也只有少量内容,集成在项目—>...storyboard 左下角菜单支持 Accessibility 、暗黑模式切换、横竖屏切换和预览。...UIButton配置.png 工具栏中停止按钮只有运行以后才会出现,并且编译运行时长形进度条改为圆形进度条。 自动补全更强大。...(3)switch 分支如果传入是枚举,会自动将所有 case 列出。 (4)遍历数组时,会自动使用数组单数形式,如数组名为names,遍历时为name。...根据书写内容可以自动导入相应模块,可以不用手动导入(目前 Beta1 还有一些问题,会有导入不了情况出现)。

1.5K20
领券