一、Jetpack Compose到底是什么
Jetpack Compose的概念
Jetpack Compose是用于構建原生Android UI的現(xiàn)代工具包。 Jetpack Compose使用更少的代碼,強大的工具和直觀的Kotlin API,簡化并加速了Android上的UI開發(fā)。這是Android Developers 官網對它的描述。
為什么我們需要一個新的UI工具
在Android中,UI工具包的歷史可追溯到至少10年前。自那時以來,情況發(fā)生了很大變化,例如我們使用的設備,用戶的期望,以及開發(fā)人員對他們所使用的開發(fā)工具和語言的期望。
以上只是我們需要新UI工具的一個原因,另外一個重要的原因是 View.java 這個類實在是太大了,有太多的代碼,它大到你甚至無法在Githubs上查看該文件,因為它實際上包含了 30000 行代碼,這很瘋狂,而我們所使用的幾乎每一個Android UI 組件都需要繼承于View。
GogleAndroid團隊的Anna-Chiara表示,他們對已經實現(xiàn)的一些API感到遺憾,因為他們也無法在不破壞功能的情況下收回、修復或擴展這些API,因此現(xiàn)在是一個嶄新起點的好時機。
這就是為什么Jetpack Compose 讓我們看到了曙光。
Jetpack Compose的著重點
包括一下幾個方面:
加速開發(fā)
強大的UI工具
直觀的Kotlin API
加速開發(fā)
如果你是一個初級開發(fā)工程師,你總是希望有更多的時間來寫業(yè)務邏輯,而不是花時間在一些如:動畫、顏色變化等事情上,看看下面這個View:
這個Material Edit-text 似乎看起來很簡單,但是其實背后有許多東西需要關注,比如:動畫、顏色改變、狀態(tài)管理等等。
而Jetpack Compose 為我們提供了很多開箱即用的Material 組件,如果的APP是使用的material設計的話,那么使用Jetpack Compose 能讓你節(jié)省不少精力。
強大的UI工具
沒有正確工具的UI工具包是無用的,因此從過去10年的經驗中能學到不少,Jetpack Compose 團隊開始和JetBrains 合作,以提供開發(fā)者強大的工具包,在Android Studio 上大規(guī)模的支持Compose 能力。
它與我們現(xiàn)在使用的Android Studio 中的 text/Design 相似,但是它更加先進,使用很簡單,這個功能只能在Android Studio4.0以上預覽版,開發(fā)compose 時使用。
直觀的Kotlin API
對于開發(fā)者而言,Jetpack Compose 的用途不僅僅是Android UI,因此用Kotlin來編寫他們并開源。當然,所有Android代碼都是開源的,但特別強調的是Compose代碼,它每天在這里更新(android.googlesource.com/platform/fr… )。因此,您可以查看和使用代碼,同時也可以在此處提供反饋。
由于Compose仍在開發(fā)之中,因此每個開發(fā)人員的反饋都很重要。
延伸閱讀:
二、Compose API 的原則
一切都是函數
正如我前面的文章所說,Compose是一個聲明式UI系統(tǒng),其中,我們用一組函數來聲明UI,并且一個Compose函數可以嵌套另一個Compose函數,并以樹的結構來構造所需要的UI。
在Compose中,我們稱該樹為UI 圖,當UI需要改變的時候會刷新此UI圖,比如Compose函數中有 if 語句,那么Kotlin編譯器就需要注意了。
頂層函數(Top-level function)
在Compose的世界中,沒有類的概念,全都是函數,并且都是頂層函數,因此不會有任何繼承和層次機構問題。
@Composable
fun checkbox ( …
@Composable
fun TextView ( … )
@Composable
fun Edittext ( … )
@Composable
fun Image ( … )
在此過程中,Compose函數始終根據接收到的輸入生成相同的UI,因此,放棄類結構不會有任何害處。從類結構構建UI過渡到頂層函數構建UI對開發(fā)者和Android 團隊都是一個巨大的轉變,頂層函數還在討論之中,還沒有發(fā)布release 版。
組合優(yōu)于繼承
Jetpack Compose優(yōu)選組合而不是繼承。 Compose會基于其他部分構建UI,但不會繼承行為。
如果你經常關注Android或者對Android有所了解,你就會知道,Android中的幾乎所有組件都繼承于View類(直接或間接繼承)。比如 EidtText 繼承于 TextView ,而同時 TextView 又繼承于其他一些View,這樣的繼承機構最終會指向跟View即 View.java 。并且 View.java 又非常多的功能。