IOS在SwiftUI中顯示模態(tài)視圖的實例代碼
簡介
這里教大家如何彈出一個簡單的模態(tài)視圖。分別有兩個頁面,ContentView
和GCPresentedView
,以下對應(yīng)簡稱為A和B。我們要做的是在A視圖中點擊按鈕跳轉(zhuǎn)到B視圖,然后再從B視圖點擊按鈕返回到A視圖。
步驟
在A視圖中創(chuàng)建按鈕和模態(tài)視圖代碼
struct ContentView: View { @State var isPresented = false var body: some View { Button(action: { self.isPresented = true }, label: { Text("Present Modally") }) .sheet(isPresented: $isPresented) { GCPresentedView() } } }
使用 @State 對屬性進(jìn)行修飾,在 SwiftUI 內(nèi)部會自動轉(zhuǎn)換為一對getter,setter,對這個屬性進(jìn)行賦值時會觸發(fā)視圖更新。
$isPresented 能夠?qū)⒅狄茫ㄒ梅椒ㄊ窃谥登胺郊右粋€$符號),當(dāng)引用的值發(fā)生改變時,這個改變會向外傳遞。
.sheet方法用于彈出一個模態(tài)視圖,在SwiftUI中的定義為。
public func sheet<Content>(isPresented: Binding<Bool>, onDismiss: (() -> Void)? = nil, @ViewBuilder content: @escaping () -> Content) -> some View where Content : View
在B視圖中創(chuàng)建按鈕和關(guān)閉模態(tài)視圖代碼
struct GCPresentedView: View { @Environment(\.presentationMode) var mode var body: some View { Button(action: { self.mode.wrappedValue.dismiss() }, label: { Text("Dismiss") }) } }
@Environment 獲取環(huán)境變量 presentationMode ,我們可以通過這個變量調(diào)用 wrappedValue.dismiss() 可以關(guān)閉模態(tài)視圖。
直接在 Xcode 運行預(yù)覽
總結(jié)
使用 SwiftUI 框架處理界面方便很多,不用太多的定義,我們只需要將界面進(jìn)行描述出來就可以了。這個教程示例中使用到了 Button 和 Text 控件,也用到了@State, Binding, @Environment 技術(shù)點。教程很簡單,放上來大家一起學(xué)習(xí),教程里的代碼已放在了GitHub上面,點擊這里獲取代碼 。
以上所述是小編給大家介紹的IOS在SwiftUI中顯示模態(tài)視圖的實例代碼,希望對大家有所幫助,也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
iOS App中UIPickerView選擇欄控件的使用實例解析
這篇文章主要介紹了iOS App中的UIPickerView選擇欄控件的使用,文中演示了兩個超詳細(xì)的例子,示例代碼為Objective-C,需要的朋友可以參考下2016-04-04iOS實現(xiàn)微信/QQ顯示最近拍攝圖片的功能實例代碼
如果你剛剛拍攝了圖片,在使用微信/QQ發(fā)生消息時會顯示“你可能要發(fā)送的圖片”,這個功能非常人性化,怎么實現(xiàn)的呢?下面小編給大家分享iOS實現(xiàn)微信/QQ顯示最近拍攝圖片的功能實例代碼,一起看看吧2017-03-03