(翻译) SwiftUI -- 创建详情页



1.png



本文原创作者:Martin Lasek
原文链接:https://medium.com/@martinlasek/swiftui-detail-view-44772246fa2a



在这个教程中,我将会展现给你知道创建一个详情页面,并且把数据传给它用于显示是多么的简单✨。

2.gif


这次的教程是跟上一个教程连起来的 (翻译) SwiftUI -- 理解 Binding,你可以先去看之前的教程再回来接着继续阅读,或者你不介意也可以跳过上一个教程,继续下去😊。



索引
  1. 创建一个详情页面(Detail View)
  2. 实现(使用)你的详情页面


1. 创建一个详情页面(Detail View)



如果你跳过了上一个教程,那么你可以从 理解 Binding CodeBase下载上个教程的代码下来,因为这个教程是基于之前的代码继续学习的。

我们的第一步是添加一些 pokemon 的图片到我们的项目中:

3.png


可以从这里去找到图片,确保每个图片名能和它们的名字对应起来。

接下来的一步是新建一个 SwiftUI View,并把它命名为 PokemonDetail

4.png


我们将会像下面一样给PokemonDetail view 添加一个图片和文本:

import SwiftUI
struct PokemonDetail: View {
  let pokemon: Pokemon
  var body: some View {
    VStack {
      Image(pokemon.name.lowercased())
      Text(pokemon.type)
      Spacer()
    }
  }
}
#if DEBUG
struct PokemonDetail_Previews: PreviewProvider {
  static var previews: some View {
    PokemonDetail(
      pokemon: Pokemon(
        id: 0,
        name: "Charmander",
        type: "Fire",
        color: .red
      )
    )
  }
}
#endif


如你所见,我们使用 pokemonname在获取对应的图片。如果你在这之前没有见过 Spacer,这是它很荣幸能见到你的一刻!Spacer的作用是填满所有剩余的空间,使整个 view 往上推,这样我们最终会得到这样的:

5.png


我们可以添加一些风格来让我们的 view 变得更好看:

import SwiftUI
struct PokemonDetail: View {
  let pokemon: Pokemon
  var body: some View {
    VStack {
      Image(pokemon.name.lowercased())
        .resizable()
        .frame(width: 200, height: 200)
      Text(pokemon.type)
        .font(.title)
        .foregroundColor(pokemon.color)
      Spacer()
    }.navigationBarTitle(Text(pokemon.name), displayMode: .inline)
  }
}
#if DEBUG
struct PokemonDetail_Previews: PreviewProvider {
  static var previews: some View {
    PokemonDetail(
      pokemon: Pokemon(
        id: 0,
        name: "Charmander",
        type: "Fire",
        color: .red
      )
    )
  }
}
#endif


我们用resizable()告诉Image, 让它调整大小,以适应它的父视图。这样在默认的情况下是填满了整个父视图,除非我们设置了frame, 让它在这个范围内使用图片。这里设置了.frame(width: 200, height: 200)

对于 Text,我们想要它稍微大一些,我们可以设置它的 size,比如 .caption / .body / .subheading / .title 等等。

到这里你应该看到一个引人注目的 PokemonDetail 视图,像这样:

6.png


2. 实现(使用)你的详情页面

准备好使用我们的PokemonDetail View 了吗?让我们在ContentView 添加如下代码:

import SwiftUI
struct Pokemon: Identifiable {
  ...
}
struct ContentView : View {
  @State var pokemonList = [ ... ]
  @State var showDetails = true
var body: some View {
    NavigationView {
      List(pokemonList) { pokemon in
        NavigationLink(destination: PokemonDetail(pokemon: pokemon) {
          HStack {
            Text(pokemon.name)
            if self.showDetails {
               Text(pokemon.type).foregroundColor(pokemon.color)
            }
          }
        }
      }
        .navigationBarTitle(Text("Pokemon"))
        .navigationBarItems(
          leading: ToggleTextButton(isOn: $showDetails),
          trailing: Button(
            action: addPokemon,
            label: { Text("Add") }
          )
        )
      }
    }
  func addPokemon() {
    ...
  }
}


让我们运行代码,看看所有的事情是如何神奇的出现的✨ 》》

7.gif
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,366评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,521评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,689评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,925评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,942评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,727评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,447评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,349评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,820评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,990评论 3 337
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,127评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,812评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,471评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,017评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,142评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,388评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,066评论 2 355

推荐阅读更多精彩内容