Flutter系列之簡單了解項目結構

前言

接下來直接進入項目的介紹活合,在這說明下我的學習路線,注重實戰(zhàn)講解绘闷,不去一個個解析官方的API是如何調(diào)用橡庞,如何使用的,因為這些官網(wǎng)已經(jīng)講的很細了印蔗,希望在項目的開發(fā)過程中扒最,遇到不明白的概念不會用的組件,再帶著問題去找答案华嘹,本期先看下Flutter的項目結構吧趣,對項目的目錄有個清晰的認識后,知道將代碼寫在哪耙厚,如何引用第三方庫强挫,如何做項目配置。

目錄如圖

項目目錄以及配置文件

通過上面圖你會發(fā)現(xiàn)一下幾個點:

  • Flutter項目實際上和React Native目錄結構一樣薛躬,都包含Android和Ios項目俯渤,都是在各自的項目中添加flutter依賴,最終集成到各自的項目中型宝。
  • Flutter是用yaml文件配置 八匠,yaml類似于標準通用標記語言的子集XML數(shù)據(jù)描述語言,語法比XML簡單很多趴酣。推薦學習鏈接 - YAML 語法— 國內(nèi)最專業(yè)的Ansible中文官方學習手冊
  • pubspec.bock 是pubsec.yaml的配置生成文件臀叙,里面包含具體依賴的版本,建議上傳git价卤,這樣保證你跟同事使用的依賴是同一個版本劝萤,保證代碼一致性,避免不必要的問題出現(xiàn)慎璧。
  • iOS代碼床嫌,使用CocoaPods管理依賴
  • Android代碼,使用Gradle管理依賴
  • lib為dart代碼胸私,使用pub管理依賴厌处,
  • Pub 包倉庫,在js中相當于npm的角色岁疼,主要管理開源項目依賴阔涉,在yaml文件中配置生效缆娃。
    如此看來,萬變不離其宗瑰排,還是React Native的套路贯要,只不過Dart語言有自己的管理套件。

Main.dart

分析下這個類椭住,如圖:
Main.dart

我們從上往下分析下這個類

  • import 導入material.dart package 在編譯器中點進去源碼看下如下
    package
    會js的朋友都不陌生崇渗,導入這個包等于是可以使用這個包下所有的組件。
  • main() lambda 表達式 實際return runApp函數(shù)京郑,傳入MyApp()對象
  • MyApp對象 繼承StatelessWidget 無狀態(tài)組件宅广,F(xiàn)lutter里面沒有像Activity一樣的角色,更像是直接使用的View些举,基于Widget做頁面而不是Activity跟狱,這樣就把Activity的雙重作用單一出來,View就是View户魏,說白了還是借鑒了React的思想兽肤。該類實現(xiàn)的build的函數(shù)就是頁面內(nèi)容渲染的關鍵。
  • MyHomePage 該類是一個有狀態(tài)的組件绪抛,繼承StatefulWiget類,實現(xiàn)createState函數(shù)电禀,并返回State狀態(tài)類的實現(xiàn)幢码。StatefulWiget并沒有狀態(tài)管理,它是不可變的尖飞,而是依賴于State做狀態(tài)管理症副,體現(xiàn)了職責單一的原則。
  • _MyHomePageState 該類是UI渲染最終的實現(xiàn)類政基,里面包含了appBar贞铣,Text,Button的使用沮明。
  • title屬性 發(fā)現(xiàn)在MyHomePage構造中傳入了title字段辕坝,可沒發(fā)現(xiàn)MyHomePage類中有人調(diào)用,直到在_MyHomePageState中才發(fā)現(xiàn)一個 widget.title的調(diào)用荐健,這樣就明白了酱畅,在Widget中定義的屬性,可以在State中通過widge.調(diào)用江场。

總結

通過對項目結構的了解纺酸,和對主頁UI的認識,感覺到Flutter設計的精髓大多數(shù)來源于React址否,有任何不明白的歡迎提問餐蔬,加油。

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市樊诺,隨后出現(xiàn)的幾起案子仗考,更是在濱河造成了極大的恐慌,老刑警劉巖啄骇,帶你破解...
    沈念sama閱讀 221,273評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件痴鳄,死亡現(xiàn)場離奇詭異,居然都是意外死亡缸夹,警方通過查閱死者的電腦和手機痪寻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,349評論 3 398
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來虽惭,“玉大人橡类,你說我怎么就攤上這事⊙看剑” “怎么了顾画?”我有些...
    開封第一講書人閱讀 167,709評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長匆笤。 經(jīng)常有香客問我研侣,道長,這世上最難降的妖魔是什么炮捧? 我笑而不...
    開封第一講書人閱讀 59,520評論 1 296
  • 正文 為了忘掉前任庶诡,我火速辦了婚禮,結果婚禮上咆课,老公的妹妹穿的比我還像新娘末誓。我一直安慰自己,他們只是感情好书蚪,可當我...
    茶點故事閱讀 68,515評論 6 397
  • 文/花漫 我一把揭開白布喇澡。 她就那樣靜靜地躺著,像睡著了一般殊校。 火紅的嫁衣襯著肌膚如雪晴玖。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,158評論 1 308
  • 那天为流,我揣著相機與錄音窜醉,去河邊找鬼。 笑死艺谆,一個胖子當著我的面吹牛榨惰,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播静汤,決...
    沈念sama閱讀 40,755評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼琅催,長吁一口氣:“原來是場噩夢啊……” “哼居凶!你這毒婦竟也來了?” 一聲冷哼從身側響起藤抡,我...
    開封第一講書人閱讀 39,660評論 0 276
  • 序言:老撾萬榮一對情侶失蹤羡微,失蹤者是張志新(化名)和其女友劉穎容劳,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,203評論 1 319
  • 正文 獨居荒郊野嶺守林人離奇死亡虑绵,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,287評論 3 340
  • 正文 我和宋清朗相戀三年御毅,在試婚紗的時候發(fā)現(xiàn)自己被綠了馋贤。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片责球。...
    茶點故事閱讀 40,427評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖贸典,靈堂內(nèi)的尸體忽然破棺而出视卢,到底是詐尸還是另有隱情,我是刑警寧澤廊驼,帶...
    沈念sama閱讀 36,122評論 5 349
  • 正文 年R本政府宣布据过,位于F島的核電站,受9級特大地震影響妒挎,放射性物質(zhì)發(fā)生泄漏绳锅。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,801評論 3 333
  • 文/蒙蒙 一酝掩、第九天 我趴在偏房一處隱蔽的房頂上張望鳞芙。 院中可真熱鬧,春花似錦庸队、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,272評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至宙拉,卻和暖如春宾尚,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背谢澈。 一陣腳步聲響...
    開封第一講書人閱讀 33,393評論 1 272
  • 我被黑心中介騙來泰國打工煌贴, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人锥忿。 一個月前我還...
    沈念sama閱讀 48,808評論 3 376
  • 正文 我出身青樓牛郑,卻偏偏與公主長得像,于是被迫代替她去往敵國和親敬鬓。 傳聞我的和親對象是個殘疾皇子淹朋,可洞房花燭夜當晚...
    茶點故事閱讀 45,440評論 2 359

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

  • 目錄 一笙各、Flutter 為何使用Dart開發(fā)語言二、Flutter的UI系統(tǒng)1.特點2.架構簡介2.1 Flut...
    十拿九穩(wěn)啦閱讀 3,666評論 3 28
  • 國慶后面兩天在家學習整理了一波flutter础芍,基本把能擼過能看到的代碼都過了一遍杈抢,此文篇幅較長,建議保存(star...
    Nealyang閱讀 4,345評論 1 17
  • 英文官網(wǎng):https://flutter.io/中文網(wǎng):https://flutterchina.club/ 首先...
    超威藍貓l閱讀 2,825評論 1 3
  • 文:溫如夏 陽光下你彈奏著一曲熟悉的旋律仑性,那曾是我最愛聽的一支曲調(diào)惶楼,它的名字就正如我此...
    溫如夏閱讀 182評論 0 2
  • 【詩 104:22-28】 日頭一出,人出去作工诊杆,勞碌直到晚上歼捐。耶和華啊,你所造的何其多刽辙,都是你用智慧造成的窥岩,遍地...
    Abigail68閱讀 548評論 0 1