使用這個(gè)版本的GetX寫(xiě)了Demo之后,發(fā)現(xiàn)有幾個(gè)問(wèn)題:
昌寧網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、APP開(kāi)發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開(kāi)發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)于2013年開(kāi)始到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來(lái)保證我們的工作的順利進(jìn)行。專(zhuān)注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
感覺(jué)不太像是穩(wěn)定版本,存在一些比較明顯的問(wèn)題;而且2.0.6到2.0.7只是一個(gè)小版本,全局狀態(tài)管理邏輯似乎就有比較大的改動(dòng)。
不支持響應(yīng)式編程,這個(gè)版本的狀態(tài)管理還是基于state的邏輯;因?yàn)橄胍容^高效的解耦頁(yè)面和邏輯,可能需要搭配響應(yīng)式編程框架。
相關(guān)功能可能比較少,沒(méi)有最新版本的功能那么全面。
Flutter是Google開(kāi)源的構(gòu)建用戶(hù)界面(UI)工具包,幫助開(kāi)發(fā)者通過(guò)一套代碼庫(kù)高效構(gòu)建多平臺(tái)精美應(yīng)用,支持移動(dòng)、Web、桌面和嵌入式平臺(tái)。
Flutter 開(kāi)源、免費(fèi),擁有寬松的開(kāi)源協(xié)議,適合商業(yè)項(xiàng)目。Flutter已推出穩(wěn)定的2.0版本。
產(chǎn)生背景:
Flutter可以方便的加入現(xiàn)有的工程中。在全世界,F(xiàn)lutter 正在被越來(lái)越多的開(kāi)發(fā)者和組織使用,并且 Flutter是完全免費(fèi)、開(kāi)源的。它也是構(gòu)建未來(lái)的 Google Fuchsia 應(yīng)用的主要方式。
Flutter組件采用現(xiàn)代響應(yīng)式框架構(gòu)建,這是從React中獲得的靈感,中心思想是用組件(widget)構(gòu)建你的UI。
組件描述了在給定其當(dāng)前配置和狀態(tài)時(shí)他們顯示的樣子。當(dāng)組件狀態(tài)改變,組件會(huì)重構(gòu)它的描述(description),F(xiàn)lutter 會(huì)對(duì)比之前的描述, 以確定底層渲染樹(shù)從當(dāng)前狀態(tài)轉(zhuǎn)換到下一個(gè)狀態(tài)所需要的最小更改。
花費(fèi)大概一個(gè)多月的時(shí)間,這個(gè)完全由Flutter編寫(xiě)的Todo-List項(xiàng)目總算初步完成了!現(xiàn)在,它終于要被開(kāi)源出來(lái)了。
在開(kāi)始介紹之前,先來(lái)簡(jiǎn)單的看一下真機(jī)運(yùn)行效果吧
下面,針對(duì)使用者和開(kāi)發(fā)者,我將來(lái)分別介紹一次
app中,可以在主題切換界面選擇各種主題顏色進(jìn)行切換,app自帶六個(gè)默認(rèn)主題,這些都是我經(jīng)過(guò)多次嘗試所挑選出來(lái)的顏色搭配。同時(shí)你也可以選擇自定義主題顏色
在app中,每項(xiàng)任務(wù)都會(huì)帶有一個(gè)圖標(biāo),而app提供了所有 Flutter 自帶的 Material design 風(fēng)格的圖標(biāo)。這些圖標(biāo),你同樣可以進(jìn)行任意顏色的自定義
在app中,有多項(xiàng)其他的操作是你可以進(jìn)行自定義的
比如說(shuō)主頁(yè)測(cè)滑欄的頭部展示內(nèi)容。當(dāng)然,還有一些其他的操作,就由你去自行體驗(yàn)了
當(dāng)你完成了一項(xiàng)任務(wù)后,這個(gè)任務(wù)就會(huì)從主頁(yè)轉(zhuǎn)移到完成列表頁(yè)面,在這里你可以看到任務(wù)的一些額外信息
那么,對(duì)于使用者的介紹就到這里結(jié)束
下面就是為廣大開(kāi)發(fā)者們介紹的時(shí)間了!
各位開(kāi)發(fā)者們請(qǐng)扶好你們的秀發(fā),下面就我來(lái)帶領(lǐng)各位參觀參觀這個(gè)項(xiàng)目的內(nèi)部構(gòu)造
項(xiàng)目中使用了一些非常優(yōu)秀的第三方庫(kù),也特別感謝這些開(kāi)發(fā)者們,讓我的發(fā)量保持健康
下面就是這些控件的信息
項(xiàng)目使用的狀態(tài)管理框架是 codeProvider/code ,而整個(gè)項(xiàng)目的架構(gòu)如下
看起來(lái)是不是和 Android 中的 MVP 模式很像呢?其實(shí)都差不多的,只是名字略有不同罷了,你也可以就把上面的模式當(dāng)作是 MVP 模式。
Flutter 可以說(shuō)是特別適合這種架構(gòu)模式的,因?yàn)橐晥D跟隨數(shù)據(jù)而變化,你基本上不用去關(guān)心View,只要去對(duì)數(shù)據(jù)進(jìn)行操作就好了。
項(xiàng)目目錄結(jié)構(gòu)如下:
先說(shuō)明一下除了 lib 外的其他目錄:
然后是 lib 目錄
項(xiàng)目創(chuàng)建于6月21日,到如今發(fā)布1.0.0版本花了三十多天的時(shí)間,雖然我做過(guò)很多測(cè)試,解決了很多bug,但是時(shí)間確實(shí)不充裕。紕漏也會(huì)在所難免
所以如果使用過(guò)程中遇到什么問(wèn)題,或者對(duì)于項(xiàng)目有什么好的建議,歡迎在app中的反饋界面提出來(lái),也可以在下面留下評(píng)論,又或者在github上提issue。
項(xiàng)目的UI設(shè)計(jì)與后臺(tái)接口均由我獨(dú)自一人完成,所以這也是為什么時(shí)間不夠的原因。不過(guò)目前項(xiàng)目中只是包含了兩個(gè)自己寫(xiě)的接口,后續(xù)計(jì)劃中應(yīng)該會(huì)加入登錄功能,到時(shí)候會(huì)有很多接口操作。
若有興趣,請(qǐng)持續(xù)關(guān)注!
如果你覺(jué)得這個(gè)app不錯(cuò),或者這個(gè)項(xiàng)目有幫助到你,不妨給這個(gè)項(xiàng)目一個(gè)Star吧。項(xiàng)目后面也會(huì)持續(xù)保持更新和維護(hù)!
ToDo-List
UI項(xiàng)目地址
密碼:Aczh
?
在 Google I/O ’17 上,Google 向我們介紹了Flutter —— 一款新的用于創(chuàng)建移動(dòng)應(yīng)用的開(kāi)源庫(kù)。
正如你所想的那樣,F(xiàn)lutter 是能夠幫助創(chuàng)建擁有漂亮 UI 界面的跨平臺(tái)移動(dòng)應(yīng)用解決方案。Flutter 的界面設(shè)計(jì)與 web 應(yīng)用類(lèi)似,因此,你能夠從 Flutter 上找到像使用 HTML/CSS 那樣熟悉的感覺(jué)。
Google 表示:Flutter 將會(huì)幫你更容易,更快速的開(kāi)發(fā)出界面美觀的移動(dòng)應(yīng)用。
聽(tīng)起來(lái)很美好,但是首先要說(shuō)的是,我對(duì)其他跨平臺(tái)解決方案,諸如 Xamarin,PhoneGap,Cordova,React Native,weex, ionic等并不是很認(rèn)可。 大家都知道,這些解決方案互有利弊,很難選擇。雖然我并不確定 Flutter 是否會(huì)與它們有所不同,但是我很期待。
Flutter 在 移動(dòng) 前端開(kāi)發(fā)上具有很多特色,很有吸引力。這篇文章,我將會(huì)告訴大家我之所以喜歡 Flutter 的真正原因,我們現(xiàn)在就開(kāi)始吧!
為什么要用 Flutter ?
你可能會(huì)好奇,然后問(wèn)自己一個(gè)問(wèn)題:
Flutter 有什么創(chuàng)新之處?它是如何工作的?與 React Native 有什么不同之處?
簡(jiǎn)要來(lái)說(shuō),F(xiàn)lutter 是一個(gè)移動(dòng) SDK ,允許我們創(chuàng)建跨平臺(tái)移動(dòng)應(yīng)用(這樣你就可以編寫(xiě)一份代碼,在 Android 和 iOS 都可以運(yùn)行這個(gè)應(yīng)用程序)。你使用dart 語(yǔ)言編寫(xiě)代碼,這是一種由谷歌開(kāi)發(fā)的語(yǔ)言,如果你以前用過(guò) Java ,那看它會(huì)覺(jué)得非常熟悉。你不再需要用 XML 文件構(gòu)建布局樹(shù),而是像這樣:
好的,現(xiàn)在就開(kāi)始吧!
1、熱重載
我們從一個(gè)基本的應(yīng)用開(kāi)始。我們有三個(gè)按鈕,它們中的每一個(gè)都能改變文本的顏色:
在玩安卓上有款組件化開(kāi)源app的項(xiàng)目,一款模仿 Eyepetizer | 開(kāi)眼視頻的 開(kāi)源app,這款app設(shè)計(jì)風(fēng)格特別喜歡的,比較簡(jiǎn)潔,美觀,然后最近又在學(xué)flutter的知識(shí),于是就寫(xiě)了一款flutter版本的開(kāi)源短視頻,效果也是聽(tīng)不錯(cuò)的,廢話(huà)不多說(shuō),先上效果圖。
先附上項(xiàng)目地址:
項(xiàng)目api會(huì)在后面的參考鏈接里,或者直接項(xiàng)目?jī)?nèi)查看。
項(xiàng)目地址:
更新:6/30 項(xiàng)目新增下拉刷新,上拉加載功能
kotlin版本開(kāi)眼短視頻開(kāi)發(fā)中,敬請(qǐng)期待...
總結(jié):在此感謝參考的伙伴的文章,寫(xiě)的也很好,然后我將這個(gè)項(xiàng)目改寫(xiě)成了flutter,當(dāng)中也學(xué)習(xí)到了很多flutter相關(guān)的知識(shí),后續(xù)還有繼續(xù)鞏固,不斷學(xué)習(xí)。
參考鏈接(包含本項(xiàng)目的api)