iOS swiftUI的实用举例

SwiftUI 是 Apple 推出的声明式 UI 框架,以下是一些实用技巧和最佳实践,可以帮助你更高效地开发 iOS/macOS/watchOS/tvOS 应用。

1. 布局技巧

灵活的空间占用

// 使用 Spacer 填充可用空间 
HStack {Text("Left")Spacer() // 填充中间空间 Text("Right")
}// 使用 frame 控制视图大小 
Text("Hello").frame(maxWidth: .infinity, maxHeight: .infinity) // 填充父视图 .background(Color.yellow)

条件显示视图

@State private var isShowing = false var body: some View {VStack {if isShowing {Text("Visible")} else {EmptyView()}// 或者使用更简洁的方式 isShowing ? Text("Visible") : nil }
}

2. 状态管理

使用 @State 和 @Binding

struct ParentView: View {@State private var text = ""var body: some View {VStack {Text("Parent: \(text)")ChildView(text: $text) // 传递绑定 }}
}struct ChildView: View {@Binding var text: String var body: some View {TextField("Enter text", text: $text)}
}

使用 @ObservedObject 和 @Published

class UserSettings: ObservableObject {@Published var score = 0 
}struct ContentView: View {@ObservedObject var settings = UserSettings()var body: some View {VStack {Text("Score: \(settings.score)")Button("Increase") {settings.score += 1 }}}
}

3. 列表与导航

动态列表

struct ContentView: View {let items = ["Apple", "Banana", "Cherry"]var body: some View {List(items, id: \.self) { item in Text(item)}}
}

带删除和移动功能的列表

struct ContentView: View {@State private var items = ["Apple", "Banana", "Cherry"]var body: some View {NavigationView {List {ForEach(items, id: \.self) { item in Text(item)}.onDelete(perform: deleteItems).onMove(perform: moveItems)}.navigationBarItems(trailing: EditButton())}}func deleteItems(at offsets: IndexSet) {items.remove(atOffsets: offsets)}func moveItems(from source: IndexSet, to destination: Int) {items.move(fromOffsets: source, toOffset: destination)}
}

4. 动画与过渡

简单动画

@State private var scale: CGFloat = 1.0 var body: some View {Button("Tap Me") {withAnimation(.spring()) {scale = scale == 1.0 ? 2.0 : 1.0 }}.scaleEffect(scale)
}

自定义过渡

@State private var showDetails = false var body: some View {VStack {Button("Toggle") {withAnimation {showDetails.toggle()}}if showDetails {Text("Details").transition(.asymmetric(insertion: .move(edge: .leading),removal: .move(edge: .trailing)))}}
}

5. 实用修饰符

同时应用多个修饰符

Text("Hello").modifier(MyCustomModifier())// 或者使用扩展 
extension View {func customStyle() -> some View {self .padding().background(Color.blue).foregroundColor(.white).cornerRadius(10)}
}Text("Hello").customStyle()

条件修饰符

@State private var isHighlighted = false var body: some View {Text("Hello").foregroundColor(isHighlighted ? .red : .blue).onTapGesture {isHighlighted.toggle()}
}

6. 性能优化

使用 Lazy 视图

ScrollView {LazyVStack { // 只渲染可见项 ForEach(0..<1000) { index in Text("Row \(index)")}}
}

使用 EquatableView 避免不必要重绘

struct UserView: View, Equatable {let user: User var body: some View {Text(user.name)}static func == (lhs: UserView, rhs: UserView) -> Bool {lhs.user.id == rhs.user.id }
}// 使用 
UserView(user: someUser).equatable()
  1. 与其他框架集成

与 UIKit 集成

struct MyUIKitView: UIViewRepresentable {func makeUIView(context: Context) -> UIActivityIndicatorView {UIActivityIndicatorView(style: .large)}func updateUIView(_ uiView: UIActivityIndicatorView, context: Context) {uiView.startAnimating()}
}// 使用 
MyUIKitView()

与 Core Data 集成

struct ContentView: View {@Environment(\.managedObjectContext) private var viewContext @FetchRequest(sortDescriptors: [NSSortDescriptor(keyPath: \Item.timestamp, ascending: true)],animation: .default)private var items: FetchedResults<Item>var body: some View {List {ForEach(items) { item in Text("Item at \(item.timestamp!, formatter: itemFormatter)")}.onDelete(perform: deleteItems)}}private func deleteItems(offsets: IndexSet) {withAnimation {offsets.map { items[$0] }.forEach(viewContext.delete)try? viewContext.save()}}
}

8. 调试技巧

调试视图层次结构

Text("Hello").debug() // 添加这个修饰符查看视图信息 extension View {func debug() -> Self {print(Mirror(reflecting: self).subjectType)return self }
}

预览多个设备

struct ContentView_Previews: PreviewProvider {static var previews: some View {Group {ContentView().previewDevice("iPhone 13")ContentView().previewDevice("iPhone SE (2nd generation)")ContentView().previewDevice("iPad Pro (12.9-inch) (5th generation)")}}
}

这些技巧可以帮助你更高效地使用 SwiftUI 构建应用程序。SwiftUI 仍在快速发展,建议定期查看 Apple 的官方文档和 WWDC 会议视频以获取最新信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/diannao/87124.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringMVC异步处理Servlet

使用SpringMVC异步处理Servlet解决的问题 可以不阻塞有限的tomcat 线程&#xff08;默认是200~250个&#xff0c;springboot3是200个&#xff09;&#xff0c;确保网络请求可以持续响应特定业务使用自定义线程池&#xff0c;可以处理的业务量更大对上层业务完全无感知&#xf…

同步与异步编程范式全景研究——从CPU时钟周期到云原生架构的范式演进

第一章 时空观的根本分歧 1.1 物理时间的约束性 同步操作的本质是对牛顿绝对时间的服从&#xff0c;其阻塞特性源于冯诺依曼体系下指令顺序执行的基因。现代CPU的流水线技术&#xff08;如Intel Hyper-Threading&#xff09;通过指令级并行实现伪异步&#xff0c;但开发者仍需…

【零散技术】5分钟完成Odoo18 登陆页面全自定义

序言:时间是我们最宝贵的财富,珍惜手上的每个时分 从最初的tinyERP到Open ERP&#xff0c;再由OpenERP到Odoo&#xff0c;虽然UI已经过了多次大改&#xff0c;Odoo登录界面依旧丑陋&#xff0c;同时还有各种Odoo版权信息&#xff0c;对于定制项目而言是不友好的。 今天以Odoo18…

Vue3 + TypeScript + Element Plus + el-pagination 分页查询实例分享

前端技术栈&#xff1a;Vue3 TypeScript Element Plus el-pagination 后端技术栈&#xff1a;Java Spring Boot Mybatis 应用异常情况说明&#xff1a;点击页码2&#xff0c;会发送两次请求&#xff0c;并且自动跳回页码1 代码&#xff1a; Reagent.vue <script set…

LoadRunner 2023 安装部署

下载地址&#xff1a;链接: https://caiyun.139.com/w/i/2nQQRYCZ1Ssjl 提取码:3gz0 复制内容打开139-云盘 主要下载Micro_Focus_LoadRunner_2023_Community_Edition.exe来安装就可以。 如要汉化&#xff0c;则再下载安装Language_Packs.exe的安装包 说明&#xff1a;LoadR…

ABC410 : F - Balanced Rectangles

https://atcoder.jp/contests/abc410/tasks/abc410_fhttps://atcoder.jp/contests/abc410/tasks/abc410_f首先可以一眼看出暴力 &#xff1a;枚举左上角和右下角&#xff0c;用前缀和算出矩形中#的数量&#xff0c;判断即可 但这样是,爆!!! 考虑优化&#xff0c;我们可以枚举…

嵌入式学习笔记 - HAL库对外设的封装

一 外设封装结构 HAL库对外设的封装使用了xx_HandleTypeDef类型的外设句柄结构体&#xff0c;这个句柄结构体的第一个成员Instance(xx_TypeDef类型)一般为该外设的所有寄存器的起始基地址&#xff0c;第二个成员Init&#xff08;xx_InitTypeDef类型&#xff09;一般为该外设的设…

高精度模板

加法 P1601 AB Problem&#xff08;高精&#xff09; #include<iostream>using namespace std; const int N 1e6 10; int a[N],b[N],c[N]; int len1,len2,lenMax; //长度要提前定义在全局&#xff0c;在函数中要使用 void add(int c[],int a[],int b[]) {for(int i0…

monorepo使用指北

|  WARN  node_modules is present. Lockfile only installation will make it out-of-date  ERR_PNPM_FETCH_404  GET https://registry.npmjs.org/common%2Fcommon: Not Found - 404 This error happened while installing a direct dependency of G:\monorepo\vue3 comm…

Java八股文——Spring「MyBatis篇」

与传统的JDBC相比&#xff0c;MyBatis的优点&#xff1f; 面试官您好&#xff0c;MyBatis相比于传统的JDBC&#xff0c;它并不是要完全颠覆JDBC&#xff0c;而是作为JDBC的一个强大的“增强框架”。它的核心价值在于&#xff0c;在保留了SQL最大灵活性的前提下&#xff0c;极大…

JavaScript基础-常用的鼠标事件

一、前言 在前端开发中&#xff0c;鼠标事件 是实现用户交互的重要手段之一。通过监听用户的点击、移动、悬停等操作&#xff0c;我们可以构建出丰富而灵活的网页交互体验。 本文将带你深入了解&#xff1a; JavaScript 中常见的鼠标事件&#xff1b;各类鼠标事件的触发时机…

windows录频软件

一.很反感有些做软件的&#xff0c;把别人开源的改个界面收费&#xff0c;所以我找了一个开源免费的。 二.准备工具 一台电脑&#xff0c; Captura:完全开源免费的录频软件。 ffmpeg&#xff1a;音频格式转换软件&#xff0c;这可是非常大名鼎鼎的工具。 三.安装Captura 网址…

python中的模块化编程:日期模块、math算术模块、random模块

内置模块&#xff08;math、random、时间&#xff09;自定义模块&#xff08;自己写的部分代码&#xff09;第三方模块&#xff08;引入的第三方代码库的模块&#xff09; math模块 import math#圆周率 print(math.pi) #自然常数 print(math.e) #圆周率的二倍 print(math.tau…

【学习笔记】Langchain基础(二)

前文&#xff1a;【学习笔记】Langchain基础 文章目录 8 [LangGraph] 实现 Building Effective Agents&#xff0c;各种 workflows 及 AgentAugmented LLMPrompt ChainingParallelizationRoutingOrchestrator-Worker (协调器-工作器)Evaluator-optimizer (Actor-Critic)Agent 8…

Java大模型开发入门 (9/15):连接外部世界(中) - 向量嵌入与向量数据库

前言 在上一篇文章中&#xff0c;我们成功地将一篇长文档加载并分割成了一系列小的文本片段&#xff08;TextSegment&#xff09;。我们现在有了一堆“知识碎片”&#xff0c;但面临一个新问题&#xff1a;计算机如何理解这些碎片的内容&#xff0c;并找出与用户问题最相关的片…

Windows下MySQL安装全流程图文教程及客户端使用指南(付整合安装包)

本教程是基于5.7版本安装&#xff0c;5.7和8.0的安装过程大差不差 安装包「windows上mysql中安装包资源」 链接&#xff1a;https://pan.quark.cn/s/de275899936d 一、安装前的准备 1.1 获取 MySQL 安装程序 官网 前往 MySQL 官方下载页面&#xff0c;下载适用于 Windows 系…

笔记 软件工程复习

第一章 软件工程学概述 1.1 软件危机&#xff08;Software Crisis&#xff09; 概念 定义&#xff1a;软件危机指在计算机软件开发与维护过程中遇到的一系列严重问题&#xff0c;源于1960年代软件复杂度激增与传统开发方法失效的矛盾。 本质&#xff1a;软件规模扩大 → 开…

GaussDB创建数据库存储

示例一&#xff1a; 下面是一个简单的GaussDB存储过程示例&#xff1a; –创建一个存储过程。 CREATE OR REPLACE PROCEDURE prc_add (param1 IN INTEGER,param2 IN OUT INTEGER ) AS BEGINparam2: param1 param2;dbe_output.print_line(result is: ||to_char(param…

基于51单片机的校园打铃及灯控制系统

目录 具体实现功能 设计介绍 资料内容 全部内容 资料获取 具体实现功能 具体功能&#xff1a; &#xff08;1&#xff09;实时显示当前时间&#xff08;年月日时分秒星期&#xff09;&#xff0c;LED模式指示灯亮。 &#xff08;2&#xff09;按下“打铃”和“打铃-”按键…

PHP+mysql雪里开轻量级报修系统 V1.0Beta

# PHP雪里开轻量级报修系统 V1.0Beta ## 简介 这是一个基于PHP7和MySQL5.6的简易报修系统&#xff0c;适用于学校、企业等机构的设备报修管理。 系统支持学生提交报修、后勤处理报修以及系统管理员管理用户和报修记录。 初代版本V1.0&#xff0c;尚未实际业务验证&#xff0c;…