Swift实用小册22: OpaqueTypes不透明类型的使用

举报
文如秋雨 发表于 2022/08/30 13:20:42 2022/08/30
【摘要】 在本章中,你将学会OpaqueTypes不透明类型的使用方法。前言和Apple官网或者网上分享的教程类文章不同,我将以实际开发角度讲述Swift语言的一些概念和用法,方便大家更好地学习和掌握Swift语言。这同时也是对自己学习Swift语言过程的知识整理。如有错误,以你为准。项目创建我们新建一个SwiftUI项目,命名为SwiftUIOpaqueTypes。不透明类型的定义不透明类型,是对泛...
在本章中,你将学会OpaqueTypes不透明类型的使用方法。

前言


和Apple官网或者网上分享的教程类文章不同,我将以实际开发角度讲述Swift语言的一些概念和用法,方便大家更好地学习和掌握Swift语言。

这同时也是对自己学习Swift语言过程的知识整理。

如有错误,以你为准。

项目创建


我们新建一个SwiftUI项目,命名为SwiftUIOpaqueTypes



不透明类型的定义


不透明类型,是对泛型的增强,不提供确定类型的返回值,我们称之为不透明类型。

不透明类型在语法上可以隐藏具体类型,简单来说就是可以不使用class类、Struct结构体,然后返回我们一种我们需要的类型。

不透明类型的使用


在之前的章节中,我们学习过Generics泛型的使用,泛型就是一种不确定类型,不透明类型的本质就是不公开的,私有的类型,只根据里面的内容返回具体的类型。示例:

import SwiftUI

struct ContentView: View {
    var body: some View {
        VStack {
            titleView()
            ListView()
        }
    }
}

struct titleView: View {
    var body: some View {
        Text("首页")
    }
}

struct ListView: View {
    var body: some View {
        List {
            ForEach(1 ... 4, id: \.self) { index in
                Text("第 \(index)页")
            }
        }
    }
}



上述代码中,是我们之前学过的通过结构体的页面构建方式,这里我们每一个View都是确定的类型,也就是Struct结构体。

Struct结构体是公开的、确定的类型。

在Swift开发过程中,我们除了class类、Struct结构体,也可以使用some关键字加我们需要返回的内容,构建返回结果。示例:

import SwiftUI

struct ContentView: View {
    var body: some View {
        VStack {
            titleView
            ListView
        }
    }
}

private var titleView: some View {
    Text("首页")
}

private var ListView: some View {
    List {
        ForEach(1 ... 4, id: \.self) { index in
            Text("第 \(index)页")
        }
    }
}



上述代码中,我们使用some关键字返回了一个View的视图,它是一个不透明类型的结果。

SwiftUI的一大特点是高度可组合,View的唯一属性 body 是另一个满足 View 约束的具体 View 类型。

我们看到了组合以及递归两个特性,这里使用了不透明返回类型的特性,对外隐藏了具体类型 VStack。

不透明类型的实例


我们可以使用不透明类型的方法,达到简化代码的目的,也就无需定义很多单独的Struct结构体完成页面样式。示例:

import SwiftUI

struct ContentView: View {
    var body: some View {

        NavigationView {
            Form {
                Section {
                    toOurSiteView
                    toPrivacyPolicyView
                    toUserAgreementView
                }
                Section {
                    toAppstoreView
                    toFeedbackView
                    toAboutView
                }
            }
            .navigationBarTitle("设置", displayMode: .inline)
            .navigationBarItems(leading: backToMineView)
        }
        
        // 显示分割线
        .onAppear {
            UITableView.appearance().separatorColor = .systemGray4
        }
    }
}



上述代码中,我们仍旧使用不透明类型的方法,创建了一个又一个View,然后在ContentView结构体中,我们使用这些OpaqueTypes不透明类型的View,既能隐藏返回类型,又保留了强类型关联,也避免了返回类型很长的问题。

这就是some的关键字作用,用在当返回值为不确定类型的情况。

本章代码


import SwiftUI
struct ContentView: View {
    var body: some View {
        NavigationView {
            Form {
                Section {
                    toOurSiteView
                    toPrivacyPolicyView
                    toUserAgreementView
                }
                Section {
                    toAppstoreView
                    toFeedbackView
                    toAboutView
                }
            }
            .navigationBarTitle("设置", displayMode: .inline)
            .navigationBarItems(leading: backToMineView)
        }
        // 显示分割线
        .onAppear {
            UITableView.appearance().separatorColor = .systemGray4
        }
    }
}
// MARK: - 返回
private var backToMineView: some View {
    Button(action: {
        // 返回上一页
    }) {
        Image(systemName: "arrow.backward.circle.fill")
            .foregroundColor(Color.gray)
    }
}
// MARK: - 访问官网
private var toOurSiteView: some View {
    Button(action: {
        // 跳转官网
    }) {
        HStack {
            Text("访问官网")
                .foregroundColor(Color.gray)
            Spacer()
            Image(systemName: "chevron.right")
                .foregroundColor(.gray)
        }
    }
}
// MARK: - 前往隐私政策页面
private var toPrivacyPolicyView: some View {
    Button(action: {
        // 进入隐私政策页面
    }) {
        HStack {
            Text("隐私政策")
                .foregroundColor(Color.gray)
            Spacer()
            Image(systemName: "chevron.right")
                .foregroundColor(.gray)
        }
    }
}
// MARK: - 前往用户协议页面
private var toUserAgreementView: some View {
    Button(action: {
        // 进入用户协议页面
    }) {
        HStack {
            Text("用户协议")
                .foregroundColor(Color.gray)
            Spacer()
            Image(systemName: "chevron.right")
                .foregroundColor(.gray)
        }
    }
}
// MARK: - 前往Appstore评分页面
private var toAppstoreView: some View {
    Button(action: {
        // 前往Appstore评分页面
    }) {
        HStack {
            Text("前往Appstore")
                .foregroundColor(Color.gray)
            Spacer()
            Image(systemName: "chevron.right")
                .foregroundColor(.gray)
        }
    }
}
// MARK: - 前往帮助反馈页面
private var toFeedbackView: some View {
    Button(action: {
        // 前往帮助反馈页面
    }) {
        HStack {
            Text("用户反馈")
                .foregroundColor(Color.gray)
            Spacer()
            Image(systemName: "chevron.right")
                .foregroundColor(.gray)
        }
    }
}
// MARK: - 前往关于页面
private var toAboutView: some View {
    Button(action: {
        // 前往关于页面
    }) {
        HStack {
            Text("关于我们")
                .foregroundColor(Color.gray)
            Spacer()
            Image(systemName: "chevron.right")
                .foregroundColor(.gray)
        }
    }
}
struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}

以上就是本章的全部内容。
快来动手试试吧!
如果本专栏对你有帮助,不妨点赞、评论、关注~
【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。