[譯] SwiftUI 官方教程 (一)
SwiftUI 簡介
SwiftUI
是一種為任何 Apple
平臺聲明用戶界面的現代化方式。以前所未有的速度,創建漂亮、動態的應用程序。
只需要描述一次的布局
為你的視圖聲明任何狀態的內容和布局,一旦狀態發生改變, SwiftUI
會自動更新視圖的渲染。
List(landmarks) { landmark in
HStack {
Image(landmark.thumbnail)
Text(landmark.name)
Spacer()
if landmark.isFavorite {
Image(systemName: "star.fill")
.foregroundColor(.yellow)
}
}
}
構建可復用的組件
將小型、獨立視圖組合到更大,更復雜的界面中。在任何為 Apple
平臺所設計的應用之間,共享您的自定義視圖。
struct FeatureCard: View {
var landmark: Landmark
var body: some View {
landmark.featureImage
.resizable()
.aspectRatio(3/2, contentMode: .fit)
.overlay(TextOverlay(landmark))
}
}
精簡動畫
創建平滑的動畫就像調用單個方法一樣簡單。 SwiftUI
會在必要時自動計算并過渡動畫。
VStack {
Badge()
.frame(width: 300, height: 300)
.animation(.basic())
Text(name)
.font(.title)
.animation(Animation.basic().delay(0.25))
}
在 Xcode 中實時預覽
無需運行應用程序,即可設計、構建和測試應用程序的界面。使用可交互的預覽來測試您的控件和布局。
作者:Willie_
鏈接:https://www.jianshu.com/p/efc36dd785d6
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。
智能推薦
【譯】【PyOpenGL教程-著色器簡介】 第一步(基本幾何)
原文地址:http://pyopengl.sourceforge.net/context/tutorials/shader_1.html 第一步(基本幾何) 在本教程中我們將會學到: - 頂點著色器在GLSL中“必須”做什么 - 片元著色器“必須”做什么 - 什么是VBO對象 - 如何**和停用著色器和VBO - 如何渲染簡單的幾何體 首先我們進行i...
【譯】Excess-XSS 一份關于 XSS 的綜合教程
原文地址:http://excess-xss.com/。如有翻譯不當之處,歡迎指出 :D 分為四部分: 概述 XSS 攻擊 XSS 防御 總結 第一部分:概述 XSS 是什么 跨站腳本攻擊(XSS)是一種代碼注入攻擊,攻擊者利用它可以在其它用戶瀏覽器中執行惡意 JavaScript。 攻擊者并不是直接面對受害者。而是,為了讓網站替自己傳輸惡意 JavaScript,攻擊者需要利用受害者訪問的網站上...
SwiftUI 一篇文章全面掌握TextField文本框 (教程和全部源碼)
本文,將是一篇系列長文,希望您通過閱讀這篇文章,基本上就可以解決TextField的所有問題。 文章目錄 快速入門 您的第一個TextField小程序 獲取用戶的輸入結果,學會回調函數(onEditingChanged 和 onCommit) 小結 使用TextField的一般流程 TextField formatters TextField textFieldStyle 基礎入門 TextFie...
SwiftUI 如何管理一組TextField(零基礎教程)
我們有一組TextField,如果簡單高效的管理他們呢。 本文價值與收獲 看完本文后,您將能夠作出下面的界面 image.png 聯動效果 看完本文您將掌握的技能 管理一組TextField 使用ScrollView 設置圓形TextField 代碼 技術交流 QQ:3365059189 SwiftUI技術交流QQ群:518696470 請關注我的專欄icloudend, SwiftUI教程與源碼...
猜你喜歡
freemarker + ItextRender 根據模板生成PDF文件
1. 制作模板 2. 獲取模板,并將所獲取的數據加載生成html文件 2. 生成PDF文件 其中由兩個地方需要注意,都是關于獲取文件路徑的問題,由于項目部署的時候是打包成jar包形式,所以在開發過程中時直接安照傳統的獲取方法沒有一點文件,但是當打包后部署,總是出錯。于是參考網上文章,先將文件讀出來到項目的臨時目錄下,然后再按正常方式加載該臨時文件; 還有一個問題至今沒有解決,就是關于生成PDF文件...
電腦空間不夠了?教你一個小秒招快速清理 Docker 占用的磁盤空間!
Docker 很占用空間,每當我們運行容器、拉取鏡像、部署應用、構建自己的鏡像時,我們的磁盤空間會被大量占用。 如果你也被這個問題所困擾,咱們就一起看一下 Docker 是如何使用磁盤空間的,以及如何回收。 docker 占用的空間可以通過下面的命令查看: TYPE 列出了docker 使用磁盤的 4 種類型: Images:所有鏡像占用的空間,包括拉取下來的鏡像,和本地構建的。 Con...
requests實現全自動PPT模板
http://www.1ppt.com/moban/ 可以免費的下載PPT模板,當然如果要人工一個個下,還是挺麻煩的,我們可以利用requests輕松下載 訪問這個主頁,我們可以看到下面的樣式 點每一個PPT模板的圖片,我們可以進入到詳細的信息頁面,翻到下面,我們可以看到對應的下載地址 點擊這個下載的按鈕,我們便可以下載對應的PPT壓縮包 那我們就開始做吧 首先,查看網頁的源代碼,我們可以看到每一...
Linux C系統編程-線程互斥鎖(四)
互斥鎖 互斥鎖也是屬于線程之間處理同步互斥方式,有上鎖/解鎖兩種狀態。 互斥鎖函數接口 1)初始化互斥鎖 pthread_mutex_init() man 3 pthread_mutex_init (找不到的情況下首先 sudo apt-get install glibc-doc sudo apt-get install manpages-posix-dev) 動態初始化 int pthread_...