flutter學(xué)習(xí)一:flutter簡(jiǎn)介

1. 簡(jiǎn)介

flutter是谷歌在2017年推出的移動(dòng)端跨平臺(tái),高性能移動(dòng)應(yīng)用框架烫止。其是通過(guò)dart語(yǔ)言進(jìn)行開(kāi)發(fā)。

主要功能:跨平臺(tái)戳稽,支持iOS馆蠕,安卓,web惊奇。開(kāi)發(fā)中支持熱重載互躬,提高開(kāi)發(fā)效率。

不支持功能:熱更新颂郎。

2. mac安裝步驟

  1. github上面下載flutter SDK, 放大本地指定文件夾吼渡。例如 "~/Library/flutter"
  2. 在 "vim ~/.bash_profile" 或者"vim ~/.zshrc"中添加flutter配置
export PUB_HOSTED_URL=https://pub.flutter-io.cn
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
export PATH=~/Library/flutter/bin:$PATH
  1. 配置Java環(huán)境,在 "vim ~/.bash_profile" 或者"vim ~/.zshrc"中添加Java環(huán)境乓序。
JAVA_HOME="/Library/Java/JavaVirtualMachines/jdk1.8.0_301.jdk/Contents/Home"
export JAVA_HOME
CLASS_PATH="$JAVA_HOME/lib"
PATH=".$PATH:$JAVA_HOME/bin"
  1. 下載xcode和Android studio編譯器
  2. 運(yùn)行 "flutter doctor", 有錯(cuò)誤的話寺酪,區(qū)網(wǎng)上搜索解決一下
  3. android studio中,通過(guò) "Preference" => "Plugins" 下載dart和flutter插件替劈。

3. 簡(jiǎn)單例子

使用android studio創(chuàng)建 "Create New Flutter Project"寄雀,并且選擇Flutter App,按照下一步選擇項(xiàng)目路徑和語(yǔ)言抬纸,完成即可咙俩。

  1. 新項(xiàng)目框架如圖:


    新項(xiàng)目架構(gòu)

主要邏輯都是在lib文件夾里面編寫(xiě)。主文件是lib/main.dart文件。

  1. 初始項(xiàng)目包含一個(gè)計(jì)數(shù)器的項(xiàng)目阿趁,功能是通過(guò)點(diǎn)擊界面浮動(dòng)按鈕膜蛔,獲取點(diǎn)擊次數(shù)。通過(guò)項(xiàng)目可以簡(jiǎn)單了解一下flutter語(yǔ)法脖阵。
// 主程序入口
void main() {
  runApp(MyApp());
}

// 創(chuàng)建一個(gè)StatelessWidget頁(yè)面皂股。
class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
        // 主題主色調(diào),具體theme后期會(huì)介紹命黔。
        primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key? key, required this.title}) : super(key: key);
  // 常量呜呐,final常量可以后期賦值一次。const需要聲明時(shí)賦值悍募。
  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _counter = 0;
  
  // 私有方法
  void _incrementCounter() {
   // 狀態(tài)改變蘑辑,通過(guò)setState,狀態(tài)更新坠宴,頁(yè)面刷新
    setState(() {
      _counter++;
    });
  }

  @override
  Widget build(BuildContext context) {
    // 常用頁(yè)面布局
    return Scaffold(
      // 導(dǎo)航欄
      appBar: AppBar(  
        title: Text(widget.title),
      ),
      body: Center(    // 頁(yè)面顯示
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Text(
              'You have pushed the button this many times:',
            ),
            Text(
              '$_counter',
              style: Theme.of(context).textTheme.headline4,
            ),
          ],
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: _incrementCounter,
        tooltip: 'Increment',
        child: Icon(Icons.add),
      ), // This trailing comma makes auto-formatting nicer for build methods.
    );
  }
}

4. 項(xiàng)目介紹

  1. 此項(xiàng)目分為iOS和android兩個(gè)移動(dòng)端展示洋魂,如果需要在iOS端運(yùn)行,需要先使用xcode進(jìn)入iOS項(xiàng)目喜鼓,選擇好開(kāi)發(fā)者證書(shū)副砍,設(shè)置好Bundle Identifier
  2. *pubspec.yaml文件時(shí)項(xiàng)目配置信息庄岖,主要是設(shè)置項(xiàng)目名稱豁翎,版本號(hào),描述等隅忿⌒陌可以設(shè)置flutter的環(huán)境。
dependencies:
  flutter:
    sdk: flutter
# 添加第三方框架

# 設(shè)置資源文件硼控,圖片
# 需要在根目錄下面添加**images/**文件夾
assets:
     - images/a_dot_burr.jpeg
  #   - images/a_dot_ham.jpeg

5. 常用架構(gòu)介紹

本人學(xué)習(xí)時(shí)根據(jù)自己思想設(shè)置架構(gòu)刘陶,僅供參考。


flutter開(kāi)發(fā)架構(gòu)
  • util: 常用的工具類牢撼,例:date時(shí)間轉(zhuǎn)換匙隔, 正則表達(dá)式驗(yàn)證等共有方法。
  • api: dio網(wǎng)絡(luò)請(qǐng)求封裝熏版。
  • base: 基礎(chǔ)依賴纷责,例如:全局時(shí)間狀態(tài)設(shè)置。scheme撼短。 provider狀態(tài)設(shè)置再膳。
  • common: 全局設(shè)置公有數(shù)據(jù)。登錄信息曲横,config, global全局配置喂柒, 網(wǎng)絡(luò)請(qǐng)求數(shù)據(jù)設(shè)置基礎(chǔ)數(shù)據(jù)等不瓶。
  • routes: 頁(yè)面路由設(shè)置。
  • sences: 頁(yè)面顯示灾杰,根據(jù)模塊展示mvvm模式蚊丐。
  • webView:設(shè)置網(wǎng)頁(yè)跳轉(zhuǎn)公有webView。

flutter初學(xué)總結(jié)艳吠,如有什么問(wèn)題麦备,歡迎評(píng)論指出。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末昭娩,一起剝皮案震驚了整個(gè)濱河市凛篙,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌栏渺,老刑警劉巖呛梆,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異磕诊,居然都是意外死亡削彬,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門秀仲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人壶笼,你說(shuō)我怎么就攤上這事神僵。” “怎么了覆劈?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵保礼,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我责语,道長(zhǎng)炮障,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任坤候,我火速辦了婚禮胁赢,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘白筹。我一直安慰自己智末,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布徒河。 她就那樣靜靜地躺著系馆,像睡著了一般。 火紅的嫁衣襯著肌膚如雪顽照。 梳的紋絲不亂的頭發(fā)上由蘑,一...
    開(kāi)封第一講書(shū)人閱讀 49,079評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼尼酿。 笑死爷狈,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的谓媒。 我是一名探鬼主播淆院,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼句惯!你這毒婦竟也來(lái)了土辩?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤抢野,失蹤者是張志新(化名)和其女友劉穎拷淘,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡入愧,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年整陌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片结洼。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖叉跛,靈堂內(nèi)的尸體忽然破棺而出松忍,到底是詐尸還是另有隱情,我是刑警寧澤筷厘,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布鸣峭,位于F島的核電站,受9級(jí)特大地震影響酥艳,放射性物質(zhì)發(fā)生泄漏摊溶。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一充石、第九天 我趴在偏房一處隱蔽的房頂上張望莫换。 院中可真熱鬧,春花似錦骤铃、人聲如沸浓镜。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)膛薛。三九已至,卻和暖如春补鼻,著一層夾襖步出監(jiān)牢的瞬間哄啄,已是汗流浹背雅任。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留咨跌,地道東北人沪么。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像锌半,于是被迫代替她去往敵國(guó)和親禽车。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

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