【Swift】100 Days of SwiftUI筆記(17-18)

筆記

本篇文章記錄一下100 Days of SwiftUI第17-18天的筆記內(nèi)容

使用TextField讀取用戶的文本

@State private var checkAmount = 0.0
@State private var numberOfPeople = 2
@State private var tipPercentage = 20

var body: some View {
    Form {
        Section {
            // TextField除了可以用Text還可以用Value傳遞Double型
            // .currency可以將輸入視為貨幣
            TextField("Amount", value: $checkAmount, format: .currency(code: "USD"))
            // 可以通過Locale獲取當(dāng)前用戶的區(qū)域設(shè)置
            // TextField("Amount", value: $checkAmount, format: .currency(code: Locale.current.currencyCode ?? "USD")))
        }
    }
}
var body: some View {
    Form {
        Section {
            TextField("Amount", value: $checkAmount, format: .currency(code: Locale.current.currencyCode ?? "USD"))
        }

        Section {
            TextField("Amount", value: $checkAmount, format: .currency(code: Locale.current.currencyCode ?? "USD"))
            .keyboardType(.decimalPad) //.decimalPad也會(huì)顯示小數(shù)
        }
    }
}

在表單中創(chuàng)建選擇器

var body: some View {
    Form {
        Section {
            TextField("Amount", value: $checkAmount, format: .currency(code: Locale.current.currencyCode ?? "USD"))
            .keyboardType(.decimalPad)

            Picker("Number of people", selection: $numberOfPeople) {
                ForEach(2 ..< 100) {
                    Text("\($0) people")
                }
            }
        }
    }
}
// 存在兩個(gè)問題
// 1.點(diǎn)擊該行不會(huì)顯示另一個(gè)屏幕
// 2.該行顯示“4 人”议谷,但我們?yōu)閚umberOfPeople屬性指定了默認(rèn)值 2
// 問題一需要添加NavigationView才能跳轉(zhuǎn)到新視圖
// 問題二是因?yàn)槭褂昧薋orEach(2 ..< 100)锐峭,從2開始創(chuàng)建,所以認(rèn)為第1行是“4 人”颜启,選中的第3行就是“4 人”

添加小費(fèi)百分比的分段控件

// .pickerStyle(.segmented) 分段控件
Section {
    Picker("Tip percentage", selection: $tipPercentage) {
        ForEach(tipPercentages, id: \.self) {
            Text($0, format: .percent)
        }
    }
    .pickerStyle(.segmented)
}

計(jì)算每人總計(jì)

var totalPerPerson: Double {
    let peopleCount = Double(numberOfPeople + 2)
    let tipSelection = Double(tipPercentage)

    let tipValue = checkAmount / 100 * tipSelection
    let grandTotal = checkAmount + tipValue
    let amountPerPerson = grandTotal / peopleCount

    return amountPerPerson
}

Section {
    Text(totalPerPerson, format: .currency(code: Locale.current.currencyCode ?? "USD"))
}
// 由于構(gòu)成總計(jì)的所有值都標(biāo)有@State,因此更改其中任何一個(gè)值都會(huì)導(dǎo)致自動(dòng)重新計(jì)算總計(jì)

隱藏鍵盤

// 文本框是否有焦點(diǎn)
// @FocusState 與常規(guī)屬性完全相同@State,只不過它是專門為處理UI中的輸入焦點(diǎn)而設(shè)計(jì)的
@FocusState private var amountIsFocused: Bool
TextField("Amount", value: $checkAmount, format: .currency(code: Locale.current.currencyCode ?? "USD"))
            .keyboardType(.decimalPad)
            .focused($amountIsFocused)


// 鍵盤上添加按鈕移除文本框焦點(diǎn),隱藏鍵盤
.toolbar { // 可以指定視圖的工具欄項(xiàng)
    ToolbarItemGroup(placement: .keyboard) { // 指定要一個(gè)鍵盤工具欄   
        Button("Done") {
            Spacer() // 靈活的空間璧尸,自動(dòng)將其他視圖推到一側(cè)
            amountIsFocused = false
        }
    }
}

總結(jié)

在此項(xiàng)目中,學(xué)習(xí)到了SwiftUI應(yīng)用程序的基本結(jié)構(gòu)熬拒、如何構(gòu)建表單爷光、創(chuàng)建導(dǎo)航視圖和導(dǎo)航欄標(biāo)題、如何使用屬性包裝器存儲(chǔ)程序狀態(tài)澎粟、如何創(chuàng)建用戶界面控件(例如@State和@FocusState)TextField以及Picker蛀序,如何使用ForEach循環(huán)創(chuàng)建視圖。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末活烙,一起剝皮案震驚了整個(gè)濱河市徐裸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌啸盏,老刑警劉巖重贺,帶你破解...
    沈念sama閱讀 216,496評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異回懦,居然都是意外死亡气笙,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,407評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門怯晕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來潜圃,“玉大人,你說我怎么就攤上這事贫贝”蹋” “怎么了?”我有些...
    開封第一講書人閱讀 162,632評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵稚晚,是天一觀的道長崇堵。 經(jīng)常有香客問我,道長客燕,這世上最難降的妖魔是什么鸳劳? 我笑而不...
    開封第一講書人閱讀 58,180評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮也搓,結(jié)果婚禮上赏廓,老公的妹妹穿的比我還像新娘。我一直安慰自己傍妒,他們只是感情好幔摸,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,198評(píng)論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著颤练,像睡著了一般既忆。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,165評(píng)論 1 299
  • 那天患雇,我揣著相機(jī)與錄音跃脊,去河邊找鬼。 笑死苛吱,一個(gè)胖子當(dāng)著我的面吹牛酪术,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播翠储,決...
    沈念sama閱讀 40,052評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼绘雁,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了彰亥?” 一聲冷哼從身側(cè)響起咧七,我...
    開封第一講書人閱讀 38,910評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎任斋,沒想到半個(gè)月后继阻,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,324評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡废酷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,542評(píng)論 2 332
  • 正文 我和宋清朗相戀三年瘟檩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片澈蟆。...
    茶點(diǎn)故事閱讀 39,711評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡墨辛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出趴俘,到底是詐尸還是另有隱情睹簇,我是刑警寧澤,帶...
    沈念sama閱讀 35,424評(píng)論 5 343
  • 正文 年R本政府宣布寥闪,位于F島的核電站太惠,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏疲憋。R本人自食惡果不足惜凿渊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,017評(píng)論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望缚柳。 院中可真熱鬧埃脏,春花似錦、人聲如沸秋忙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,668評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽灰追。三九已至堵幽,卻和暖如春旁壮,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谐檀。 一陣腳步聲響...
    開封第一講書人閱讀 32,823評(píng)論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留裁奇,地道東北人桐猬。 一個(gè)月前我還...
    沈念sama閱讀 47,722評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像刽肠,于是被迫代替她去往敵國和親溃肪。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,611評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容