SwiftUI直通车系列(2)—— 列表视图

简介: SwiftUI直通车系列(2)—— 列表视图

列表视图的开发中非常常用的页面元素。SwiftUI中也有专门用来渲染列表的元素提供。


一、编写行视图


     列表实际上是一组行视图的组合,在布局列表视图之前,你首先需要定义好行视图的布局。例如,我们使用一个Image元素和两个Text元素来布局一个简单的联系人行视图。


struct RowContent:View {

   var body: some View {

       HStack(alignment:.top) {

           Image("demo").resizable().frame(width: 70, height: 70)

           VStack(alignment:.leading, spacing: 10) {

               Text("王小丫").bold().font(Font.system(size: 25))

               Text("15137344444").font(Font.system(size: 20))

           }

           Spacer()

           }.padding(EdgeInsets(top: 10, leading: 20, bottom: 10, trailing: 20))

   }

}

在预览界面上与布局情况进行预览,如下图:


    image.png


二、关联数据


    列表中展示的数据往往是一组相似类型的数据。以上联系人行视图为例,我们可以定义一组联系人数据来填充到列表的行视图中。首先定义一个结构体用来描述联系人信息,如下:


struct ContactModel {

   var name:String

   var phone:String

}


let modelData = [

   ContactModel(name:"王小丫", phone:"15137348888"),

   ContactModel(name:"李小二", phone:"15137348989")

]

如上代码所示,其中ContactModel定义了联系人的基本信息,modelData是一组联系人模型,实际应用中,modelData的数据来源可能是网络,也可能是本地文件。修改RowContent代码如下:


struct RowContent:View {

 

   var contactModel:ContactModel

 

   var body: some View {

       HStack(alignment:.top) {

           Image("demo").resizable().frame(width: 70, height: 70)

           VStack(alignment:.leading, spacing: 10) {

               Text(self.contactModel.name).bold().font(Font.system(size: 25))

               Text(self.contactModel.phone).font(Font.system(size: 20))

           }

           Spacer()

           }.padding(EdgeInsets(top: 10, leading: 20, bottom: 10, trailing: 20))

   }

}

SwiftUI的实时预览功能也支持对一组组件进行预览,示例如下:


struct ContentView_Previews: PreviewProvider {

   static var previews: some View {

       Group {

           RowContent(contactModel: modelData[0])

           RowContent(contactModel: modelData[1])

       }.previewLayout(.fixed(width: 400, height: 80))

   }

}

效果如下图所示:


image.png


三、使用列表组件


    SwiftUI中使用List组件来构建列表,将布局好的列表行视图嵌入其中即可展示出列表界面,如下:


struct ListContent:View {

   var body: some View {

       List {

          RowContent(contactModel: modelData[0])

          RowContent(contactModel: modelData[1])

       }

   }

}


struct ContentView_Previews: PreviewProvider {

   static var previews: some View {

       ListContent()

   }

}

此时,预览效果如下图所示:


image.png


在实际开发中,一般我会采用动态的方式来构建列表,通过对数据源的便利,可以循环生成列表行,示例如下:


struct ListContent:View {

   var body: some View {

       List(modelData, id: \.name) { model in

          RowContent(contactModel: model)

       }

   }

}

其中id是一个行标识字段,使用数据源中能够保证唯一的字段来设置即可。

目录
相关文章
swift UI专项训练4 场景过渡-转场
    上一话中我们创建了两个场景,这一话我们想要实现两个场景间的过渡。我们只需要增加一个导航条。
869 0
|
Swift
Swift UI专项训练3 第二个场景
    上一话中我们新建了一个textView,这一话我们来建一个列表,这个列表和上一话中的text不在一个页面中怎么办,直接拖拽Table View Controller到storyboard中,会多出一个屏幕来,效果如图: 注意一下左边,现在我们是有两个场景的,下面的View Controller是我们创建工程就有的,而上面的是我们刚才新建出的Table View Controller。
806 0
|
8月前
|
安全 编译器 Swift
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
IOS开发基础知识: 对比 Swift 和 Objective-C 的优缺点。
440 2
|
6月前
|
Unix 调度 Swift
苹果iOS新手开发之Swift 中获取时间戳有哪些方式?
在Swift中获取时间戳有四种常见方式:1) 使用`Date`对象获取秒级或毫秒级时间戳;2) 通过`CFAbsoluteTimeGetCurrent`获取Core Foundation的秒数,需转换为Unix时间戳;3) 使用`DispatchTime.now()`获取纳秒级精度的调度时间点;4) `ProcessInfo`提供设备启动后的秒数,不表示绝对时间。不同方法适用于不同的精度和场景需求。
191 3
|
2月前
|
安全 Swift iOS开发
Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法
本文深入探讨了 Swift 与 UIKit 在 iOS 应用界面开发中的关键技术和实践方法。Swift 以其简洁、高效和类型安全的特点,结合 UIKit 丰富的组件和功能,为开发者提供了强大的工具。文章从 Swift 的语法优势、类型安全、编程模型以及与 UIKit 的集成,到 UIKit 的主要组件和功能,再到构建界面的实践技巧和实际案例分析,全面介绍了如何利用这些技术创建高质量的用户界面。
34 2
|
2月前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户点击按钮时,按钮将从圆形变为椭圆形,颜色从蓝色渐变到绿色;释放按钮时,动画以相反方式恢复。通过UIView的动画方法和弹簧动画效果,实现平滑自然的过渡。
70 1
|
3月前
|
Swift iOS开发 UED
如何使用Swift和UIKit在iOS应用中实现自定义按钮动画
【10月更文挑战第18天】本文通过一个具体案例,介绍如何使用Swift和UIKit在iOS应用中实现自定义按钮动画。当用户按下按钮时,按钮将从圆形变为椭圆形并从蓝色渐变为绿色;释放按钮时,动画恢复原状。通过UIView的动画方法和弹簧动画效果,实现平滑自然的动画过渡。
64 5
|
5月前
|
存储 移动开发 Swift
使用Swift进行iOS应用开发:探索现代移动开发的魅力
【8月更文挑战第12天】使用Swift进行iOS应用开发,不仅能够享受到Swift语言带来的简洁、快速、安全的编程体验,还能够充分利用iOS平台提供的丰富资源和强大功能。然而,iOS应用开发并非易事,需要开发者具备扎实的编程基础、丰富的实践经验和不断学习的精神。希望本文能够为您的iOS应用开发之旅提供一些有益的参考和帮助。
|
6月前
|
Swift iOS开发 Kotlin
苹果iOS新手开发之Swift中实现类似Kotlin的作用域函数
Swift可通过扩展实现类似Kotlin作用域函数效果。如自定义`let`, `run`, `with`, `apply`, `also`,增强代码可读性和简洁性。虽无直接内置支持,但利用Swift特性可达成相似功能。
81 7
|
6月前
|
调度 Swift Android开发
苹果iOS新手开发之Swift中的并发任务和消息机制
Swift的消息机制类似Android的Handler,实现任务调度有三种方式: 1. **Grand Central Dispatch (GCD)**:使用`DispatchQueue`在主线程或后台线程执行任务。 2. **OperationQueue**:提供高级接口管理`Operation`对象。 3. **RunLoop**:处理事件如输入源、计时器,类似Android的`Looper`和`Handler`。 **示例**: - GCD:在不同线程执行代码块。 - OperationQueue:创建操作并执行。 - RunLoop:用Timer添加到RunLoop中。
111 2