Flutter、Dart學(xué)習(xí)總結(jié)

  • Container

添加 padding, margins, borders, background color, 或?qū)⑵渌b飾添加到widget

  • Scaffold

使用Scaffold是最容易的嘁圈,它是 Material Components庫(kù)中的一個(gè)widget,它提供了一個(gè)默認(rèn)banner蟀淮,背景顏色最住,并且具有添加drawer,snack bar和底部sheet的API

  • DefaultTextStyle

DefaultTextStyle.merge可以允許您創(chuàng)建一個(gè)默認(rèn)的文本樣式灭贷,該樣式會(huì)被其所有的子節(jié)點(diǎn)繼承

  • maxCrossAxisExtent

GridView.extent中maxCrossAxisExtent的作用

  • SizedBox

能強(qiáng)制子控件具有特定寬度温学、高度或兩者都有,使子控件設(shè)置的寬高失效

        new SizedBox(
          width: 100.0,
          height: 100.0,
          child: Container(
            width: 200.0,
            height: 200.0,
            color: Color(0xffff0000),
          ),
        )
  • State狀態(tài)管理

  1. 如果狀態(tài)是用戶數(shù)據(jù)略贮,如復(fù)選框的選中狀態(tài)甚疟、滑塊的位置,則該狀態(tài)最好由父widget管理
  2. 如果所討論的狀態(tài)是有關(guān)界面外觀效果的逃延,例如動(dòng)畫(huà)览妖,那么狀態(tài)最好由widget本身來(lái)管理
  3. 如果有疑問(wèn),首選是在父widget中管理狀態(tài)
  • flutter的Key

Flutter-->何時(shí)需要使用到key揽祥?
flutter 中的 key

  • flutter的json轉(zhuǎn)為實(shí)體類(lèi)插件(Android Studio插件)

AS中搜索插件FlutterJsonBeanFactory讽膏,安裝,重啟AS拄丰。
在指定目錄下府树,右鍵,new - dart bean class File From JSON料按,粘貼進(jìn)json奄侠,格式化,生成即可载矿。

路徑

  • dart中export使用

在A庫(kù)中使用export關(guān)鍵字引入B庫(kù)垄潮,當(dāng)我們使用A庫(kù)的時(shí)候,會(huì)自動(dòng)引入B庫(kù),也就是說(shuō)我們導(dǎo)入了A庫(kù)弯洗,就可以使用B庫(kù)了旅急。

  • cupertino下push的同時(shí),隱藏tabbar

Navigator.of(context, rootNavigator: true)
          .push(CupertinoPageRoute(builder: (BuildContext context) {
        return new MsgCenterPage();
      }));
  • flutter使用16進(jìn)制色值

Color(0xFFFF8A65)其中0x后面的兩位FF表示透明度16進(jìn)制牡整,F(xiàn)F后面為色值

  • flutter獲取屏幕寬高和狀態(tài)欄高度

/** 獲取屏幕寬度 */
  static double getScreenWidth(BuildContext context) {
    return MediaQuery.of(context).size.width;
  }

  /** 獲取屏幕高度 */
  static double getScreenHeight(BuildContext context) {
    return MediaQuery.of(context).size.height;
  }

  /** 獲取系統(tǒng)狀態(tài)欄高度 */
  static double getSysStatsHeight(BuildContext context) {
    return MediaQuery.of(context).padding.top;
  }
  • GestureDetector為布局添加手勢(shì)藐吮,child和空白區(qū)域全部可點(diǎn)擊

GestureDetector的child添加為Container,同時(shí)Container要設(shè)置color逃贝,整體Container的child和空白區(qū)域才全部可點(diǎn)擊炎码,否則則是Container的child可點(diǎn)而空白不可點(diǎn)擊。

  • 隱藏鍵盤(pán)

FocusScope.of(context).requestFocus(FocusNode());
  • dynamic的使用

在數(shù)據(jù)解析過(guò)程中秋泳,如果不確定當(dāng)前類(lèi)型的話潦闲,可以使用dynamic來(lái)代替,具體是某個(gè)類(lèi)型的話迫皱,再轉(zhuǎn)為某個(gè)類(lèi)型歉闰。


@JsonSerializable()
class ResultData extends Object {

  @JsonKey(name: 'code')
  String code;

  @JsonKey(name: 'data')
  dynamic data;

  @JsonKey(name: 'url')
  String url;

  @JsonKey(name: 'message')
  String message;

  ResultData(this.code,this.data,this.url,this.message,);

  factory ResultData.fromJson(Map<String, dynamic> srcJson) => _$ResultDataFromJson(srcJson);

  Map<String, dynamic> toJson() => _$ResultDataToJson(this);

}
  • flutter延遲執(zhí)行

new Future.delayed(Duration(seconds: 2), () {
        Navigator.of(context).pop();
      });
  • flutter中url中編碼解碼

例如:需要將
js://iOSAction?%7B%22method%22:%22toLogin%22%7D
轉(zhuǎn)為
js://iOSAction?{"method":"toLogin"}
使用Uri的decode方法:
String url = Uri.decodeFull(navigation.url);
相反,編碼的話卓起,使用Uri的encode方法和敬。

  • flutter的圖片布局填充滿父布局

方法一:
new ConstrainedBox(
                  constraints: new BoxConstraints.expand(),
                  child: new FadeInImage.assetNetwork(
                    placeholder: "assets/home/placeholder_default.png",
                    image: model != null
                        ? "${APIConfig.pictureURL}"
                        "${model.pictureUrl}"
                        : null,
                    fit: BoxFit.fill,
                  ),
                ),

方法二:
如果已知寬高,Image里直接定義指定的寬和高
MediaQuery.of(context).size.width
MediaQuery.of(context).size.height
  • Text超出省略號(hào)截?cái)?/h4>

TextOverflow.ellipsis

new Text(
                  '我愛(ài)北京天安門(mén)戏阅,我愛(ài)北京天安門(mén)昼弟,我愛(ài)北京天安門(mén),我愛(ài)北京天安門(mén)奕筐,我愛(ài)北京天安門(mén)舱痘,我愛(ài)北京天安門(mén),我愛(ài)北京天安門(mén)',
                  overflow: TextOverflow.ellipsis,
                ),
  • list通過(guò)map轉(zhuǎn)化的時(shí)候獲取index

list通過(guò)asMap轉(zhuǎn)為Map离赫,然后使用Map.map獲取index芭逝。

    homeNoticeList
        .asMap()
        .map((index, model) => MapEntry(
              index,
              new GestureDetector(
                onTap: () {
                  logPrint(index, message: "我點(diǎn)擊了滾動(dòng)的廣告");
                },
                child: new Container(
                  color: ColorConfig.white,
                  child: new Align(
                    alignment: Alignment.centerLeft,
                    child: new Text(
                      model.title,
                      style: new TextStyle(fontSize: 14.0),
                      overflow: TextOverflow.ellipsis,
                    ),
                  ),
                ),
              ),
            ))
        .values
        .toList();
  • Cookie管理

網(wǎng)絡(luò)請(qǐng)求使用dio進(jìn)行網(wǎng)絡(luò)請(qǐng)求,可以添加cookiemanager攔截器渊胸,來(lái)對(duì)cookie進(jìn)行自動(dòng)管理旬盯,也可手動(dòng)刪除cookie。
Flutter中添加依賴

  dio: ^2.1.7 # 網(wǎng)絡(luò)請(qǐng)求
  cookie_jar: ^1.0.0 # cookie管理

dio請(qǐng)求封裝中翎猛,添加攔截器:

// 添加`Cookie`管理
    dio.interceptors.add(CookieManager(CookieJar()));

然后在requestheaders中會(huì)自動(dòng)增加

cookie: SESSION=9d41c3e9-5619-492f-aa92-d85add6b04ed

iOSmoya cookie不一樣胖翰,一個(gè)是cookie,一個(gè)是"Set-Cookie"(header中拼入):

["Set-Cookie":SESSION=9d41c3e9-5619-492f-aa92-d85add6b04ed]
  • Appbar中使用自定義的返回按鈕

先設(shè)置automaticallyImplyLeadingfalse切厘,然后在leading中設(shè)置返回按鈕萨咳。

automaticallyImplyLeading: false,
      leading: new GestureDetector(
        onTap: () {
          Navigator.of(context).pop();
        },
        child: new Image.asset('assets/common/nav_back_arrow.png'),
      ),
  • 設(shè)置appbar高度

appBar: new PreferredSize(
        child: appBar,
        preferredSize: Size.fromHeight(44),
      ),
  • 使用webview_flutter時(shí)執(zhí)行調(diào)用js的方法:

推薦在onPageFinished里調(diào)用。
例如:

onPageFinished: (String url) {
                      print("page finished loading: $url");
                      setState(() {
                        isLoading = false;
                      });

                      // 如果為項(xiàng)目風(fēng)險(xiǎn)等級(jí)的url迂卢,則執(zhí)行隱藏header的js某弦。
                      if (widget.url == ContentConfig.projectRiskLevel) {
                        _controller.future.then((controller) {
                          controller
                              .evaluateJavascript('hideHeader();')
                              .then((result) {});
                        });
                      }
                    }
  • android studio中使用print打印桐汤,只能打印出一部分的解決辦法:

導(dǎo)入foundation庫(kù):
import 'package:flutter/foundation.dart';
使用flutterfoundation中的debugPrint打印即可打印全部。

  • TabBar對(duì)應(yīng)的TabController使用代碼切換tabBar (index從0開(kāi)始):

controller.animateTo(index);
  • flutter富文本RichText使用

RichText在段落中顯示不同樣式

  • 復(fù)制到粘貼板

import 'package:flutter/services.dart';

  static copyToClipboard(final String text) {
    if (text == null) return;
    Clipboard.setData(new ClipboardData(text: text));
  }
  • 返回當(dāng)前的時(shí)間戳

static int currentTimeMillis() {
    return new DateTime.now().millisecondsSinceEpoch;
  }
  • 返回文件大小字符串

static const RollupSize_Units = ["GB", "MB", "KB", "B"];
  /** 返回文件大小字符串 */
  static String getRollupSize(int size) {
    int idx = 3;
    int r1 = 0;
    String result = "";
    while (idx >= 0) {
      int s1 = size % 1024;
      size = size >> 10;
      if (size == 0 || idx == 0) {
        r1 = (r1 * 100) ~/ 1024;
        if (r1 > 0) {
          if (r1 >= 10)
            result = "$s1.$r1${RollupSize_Units[idx]}";
          else
            result = "$s1.0$r1${RollupSize_Units[idx]}";
        } else
          result = s1.toString() + RollupSize_Units[idx];
        break;
      }
      r1 = s1;
      idx--;
    }
    return result;
  }
  • flutter調(diào)起撥打電話

import 'package:url_launcher/url_launcher.dart';

Future<void> _launched;

Future<void> _makePhoneCall(String url) async {
    if (await canLaunch(url)) {
      await launch(url);
    } else {
      throw 'Could not launch $url';
    }
  }

// 調(diào)起撥打電話
          setState(() {
            _launched = _makePhoneCall('tel:18612345678');
          });
  • 垂直分割線

Container(
                  height: 40,
                  child: VerticalDivider(color: Colors.red),
                ),
  • 可取消的定時(shí)任務(wù)

Timer代替Future.

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末靶壮,一起剝皮案震驚了整個(gè)濱河市怔毛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌腾降,老刑警劉巖拣度,帶你破解...
    沈念sama閱讀 218,386評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異螃壤,居然都是意外死亡抗果,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,142評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)奸晴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)冤馏,“玉大人,你說(shuō)我怎么就攤上這事寄啼〈猓” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,704評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵墩划,是天一觀的道長(zhǎng)涕刚。 經(jīng)常有香客問(wèn)我,道長(zhǎng)乙帮,這世上最難降的妖魔是什么杜漠? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,702評(píng)論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮察净,結(jié)果婚禮上驾茴,老公的妹妹穿的比我還像新娘。我一直安慰自己塞绿,他們只是感情好沟涨,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,716評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著异吻,像睡著了一般。 火紅的嫁衣襯著肌膚如雪喜庞。 梳的紋絲不亂的頭發(fā)上诀浪,一...
    開(kāi)封第一講書(shū)人閱讀 51,573評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音延都,去河邊找鬼雷猪。 笑死,一個(gè)胖子當(dāng)著我的面吹牛晰房,可吹牛的內(nèi)容都是我干的求摇。 我是一名探鬼主播射沟,決...
    沈念sama閱讀 40,314評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼与境!你這毒婦竟也來(lái)了验夯?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,230評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤摔刁,失蹤者是張志新(化名)和其女友劉穎挥转,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體共屈,經(jīng)...
    沈念sama閱讀 45,680評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绑谣,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,873評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了拗引。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片借宵。...
    茶點(diǎn)故事閱讀 39,991評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖矾削,靈堂內(nèi)的尸體忽然破棺而出暇务,到底是詐尸還是另有隱情,我是刑警寧澤怔软,帶...
    沈念sama閱讀 35,706評(píng)論 5 346
  • 正文 年R本政府宣布垦细,位于F島的核電站,受9級(jí)特大地震影響挡逼,放射性物質(zhì)發(fā)生泄漏悠就。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,329評(píng)論 3 330
  • 文/蒙蒙 一厦画、第九天 我趴在偏房一處隱蔽的房頂上張望撬呢。 院中可真熱鬧,春花似錦虱疏、人聲如沸惹骂。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,910評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)对粪。三九已至,卻和暖如春装蓬,著一層夾襖步出監(jiān)牢的瞬間著拭,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,038評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工牍帚, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留儡遮,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,158評(píng)論 3 370
  • 正文 我出身青樓暗赶,卻偏偏與公主長(zhǎng)得像鄙币,于是被迫代替她去往敵國(guó)和親肃叶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,941評(píng)論 2 355