成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

【Flutter】開發(fā)之實(shí)戰(zhàn)Widget(四)

funnyZhang / 1105人閱讀

摘要:開發(fā)之目錄頁(yè)面跳轉(zhuǎn)的頁(yè)面跳轉(zhuǎn),主要是通過(guò)來(lái)實(shí)現(xiàn),類似原生中的路由,分為靜態(tài)和動(dòng)態(tài)種方式。添加添加,這時(shí),就可以這樣使用你的認(rèn)可,是我堅(jiān)持更新博客的動(dòng)力,如果覺得有用,就請(qǐng)點(diǎn)個(gè)贊,謝謝

前言

這一篇,我們說(shuō)說(shuō)開發(fā)中會(huì)用到的地方。

【Flutter】開發(fā)之目錄

頁(yè)面跳轉(zhuǎn)

Flutter的頁(yè)面跳轉(zhuǎn),主要是通過(guò)Navigator來(lái)實(shí)現(xiàn),類似原生中的路由,分為靜態(tài)和動(dòng)態(tài)2種方式。

靜態(tài)

首先要在MaterialApproutes中進(jìn)行注冊(cè)

MaterialApp(
      routes: {
        "base": (BuildContext context) {
          return BaseDemo();
        },
        "login": (BuildContext context) {
          return LoginDemo();
        }
      },
      title: "Flutter Demo",
      theme: ThemeData(
        primarySwatch: Colors.brown,
      ),
      home: MainDemo(),
    );

然后進(jìn)行跳轉(zhuǎn)

              RaisedButton(
                child: Text("BaseWidget"),
                onPressed: () {
                  Navigator.pushNamed(context, "base");
                },
              )

這種方式的缺點(diǎn)也比較明顯,首先需要注冊(cè),其次是不能傳遞參數(shù)

動(dòng)態(tài)

需要構(gòu)建MaterialPageRoute

              RaisedButton(
                child: Text("PageView"),
                onPressed: () {
                  Navigator.push(context,
                      new MaterialPageRoute(builder: (BuildContext context) {
                    return PageViewDemo();
                  }));
                },
              )

關(guān)閉頁(yè)面

主要是通過(guò)pop方法來(lái)實(shí)現(xiàn) Navigator.of(context).pop();

傳遞參數(shù)

首先,需要在目標(biāo)Widget中定義參數(shù)

class LoginDemo extends StatefulWidget {
  @override
  _LoginDemoState createState() => _LoginDemoState(tel);

  final String tel;

  LoginDemo({Key key, @required this.tel}) : super(key: key);
}

再傳遞參數(shù)

              RaisedButton(
                child: Text("Login"),
                onPressed: () {
                  Navigator.push(context,
                      new MaterialPageRoute(builder: (BuildContext context) {
                    return LoginDemo(tel: "18700000000");
                  }));
                },
              )

目標(biāo)Widget取值,這里用到的是上一篇中的登錄示例,詳情可以查看【Flutter】開發(fā)之高級(jí)Widget(三)

class _LoginDemoState extends State<LoginDemo> {
  String tel;

  _LoginDemoState(this.tel);

  TextEditingController user = new TextEditingController();
  TextEditingController pwd = new TextEditingController();

  @override
  void initState() {
    super.initState();
    setState(() {
      user.text = tel;
    });
  }
}

這里通過(guò)setState觸發(fā)Widget重新構(gòu)建刷新,將傳遞來(lái)的值設(shè)置給目標(biāo)TextField

回傳參數(shù)

首先是在關(guān)閉時(shí),加入?yún)?shù) Navigator.of(context).pop("0000000"); 接收時(shí),靜態(tài)和動(dòng)態(tài)方式的參數(shù)回傳都是通過(guò)then方法來(lái)完成的,這里就以動(dòng)態(tài)方式為例

              RaisedButton(
                child: Text("Login"),
                onPressed: () {
                  Navigator.push(context,
                      new MaterialPageRoute(builder: (BuildContext context) {
                    return LoginDemo(tel: "18700000000");
                  })).then((onValue) {
                    buildDialog(context, onValue);
                  });
                },
              )
  void buildDialog(BuildContext context, String text) {
    showDialog(
      context: context,
      builder: (BuildContext content) {
        return AlertDialog(
          title: Text("提示"),
          content: Text(text),
          actions: [
            GestureDetector(
              child: Container(
                child: Text("關(guān)閉"),
              ),
              onTap: () {
                Navigator.of(context).pop();
              },
            ),
          ],
        );
      },
    );
  }

網(wǎng)絡(luò)請(qǐng)求

flutter內(nèi)置HttpClient可以用來(lái)做網(wǎng)絡(luò)請(qǐng)求,但是官方建議使用 dio

官方原話: HttpClient本身功能較弱,很多常用功能都不支持。我們建議您使用dio?來(lái)發(fā)起網(wǎng)絡(luò)請(qǐng)求,它是一個(gè)強(qiáng)大易用的dart http請(qǐng)求庫(kù),支持Restful API、FormData、攔截器、請(qǐng)求取消、Cookie管理、文件上傳/下載

我們就從善如流,直接使用dio來(lái)實(shí)現(xiàn)網(wǎng)絡(luò)請(qǐng)求

pubspec.yaml文件中添加依賴 dio: ^2.1.4

  void getData() {
    Dio dio = new Dio();
    dio.request(
      //使用自己的接口
      "https://***/module/index.php");,
      data: {"p", "1"},
    ).then((onValue) {
      print(onValue);
      setState(() {
        jsonString = onValue;
      });
    });
  }

關(guān)于dio的更多用法,請(qǐng)參考 dio 官方文檔

將請(qǐng)求返回的數(shù)據(jù)展示到Text

  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("NetDemo"),
        actions: [
          RaisedButton(
            child: Text("發(fā)起請(qǐng)求"),
            onPressed: () {
              getData();
            },
          ),
        ],
      ),
      body: Container(
        child: Text("${jsonString}"),
      ),
    );
  }

JSON 序列化

上一步中,我們拿到了網(wǎng)絡(luò)請(qǐng)求返回的json,怎么把它轉(zhuǎn)換為對(duì)象呢?這就涉及到了序列化

1.flutter 內(nèi)置的 json,老版本中為JSON

首先,添加導(dǎo)入 import "dart:convert";

  void getData() {
    Dio dio = new Dio();
    dio.request(
      "https://***/module/index.php");,
      data: {"p", "1"},
    ).then((onValue) {
      print(onValue);
      //dynamic 代表動(dòng)態(tài)數(shù)據(jù)類型 即可以是數(shù)字、字符串等任意類型
      Map list = json.decode(onValue.toString());

      setState(() {
        data = list["data"];
      });
    });
  }

使用數(shù)據(jù)

  Widget _listView() {
    return ListView.builder(
      itemBuilder: (context, index) {
        return MoveItem(data[index]);
      },
      itemCount: data.length,
    );
  }

class MoveItem extends StatelessWidget {
  var model;

  MoveItem(this.model);

  @override
  Widget build(BuildContext context) {
    return Container(     
            child: Image.network(
              "http://chuangfen.oss-cn-hangzhou.aliyuncs.com" +
                  model["head_image"],
            ),
    );
}

雖然說(shuō)問(wèn)題解決了,但是這種方式的弊端很明顯,我們直到運(yùn)行時(shí)才知道值的類型,這樣會(huì)失去了大部分靜態(tài)類型語(yǔ)言特性:類型安全、自動(dòng)補(bǔ)全和最重要的編譯時(shí)異常。這樣一來(lái),我們的代碼可能會(huì)變得非常容易出錯(cuò)。

2.手動(dòng)序列化

只需要添加BaseModel,并傳入泛型,在其中添加json轉(zhuǎn)對(duì)象的方法即可。

添加BaseModel

import "dart:convert";

class BaseModel<T> {
  int status;
  String msg;
  T data;

  BaseModel(this.status, this.msg, this.data);

  BaseModel.fromJson(String jsonString) {
    Map data = json.decode(jsonString);
    BaseModel(data["status"], data["msg"], data["data"]);
  }

  Map toJson() => {
        "status": status,
        "msg": msg,
        "data": data,
      };
}

添加ExpertModel

class ExpertModel {
  String nick_name;
  String head_image;
  String id;
  String signature;
}

這時(shí),就可以這樣使用

  void getData() {
    Dio dio = new Dio();
    dio.request(
      "https://www.yfbr2018.com/module/index.php");,
      data: {"p", "1"},
    ).then((onValue) {
      BaseModel> baseModel =
          BaseModel>.fromJson(onValue.toString());

      setState(() {
        jsonString = onValue;
        data = baseModel.data;
      });
    });
  }

class MoveItem extends StatelessWidget {
  ExpertModel model;

  MoveItem(this.model);

  @override
  Widget build(BuildContext context) {
    return Container(     
            child: Image.network(
              "http://chuangfen.oss-cn-hangzhou.aliyuncs.com" +
                 model.head_image,
            ),
    );
}

你的認(rèn)可,是我堅(jiān)持更新博客的動(dòng)力,如果覺得有用,就請(qǐng)點(diǎn)個(gè)贊,謝謝

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/6980.html

相關(guān)文章

  • Flutter交互實(shí)戰(zhàn)-即刻App探索頁(yè)下拉&拖拽效果

    摘要:前言最近比較熱門,但是成體系的文章并不多,前期避免不了踩坑我這篇文章主要介紹如何使用實(shí)現(xiàn)一個(gè)比較復(fù)雜的手勢(shì)交互,順便分享一下我在使用過(guò)程中遇到的一些小坑,減少大家入坑作者鏈接先睹為快本項(xiàng)目支持運(yùn)行,效果如下對(duì)了,順便分享一下生成的小竅門,建 前言 Flutter最近比較熱門,但是Flutter成體系的文章并不多,前期避免不了踩坑;我這篇文章主要介紹如何使用Flutter實(shí)現(xiàn)一個(gè)比較復(fù)雜...

    miracledan 評(píng)論0 收藏0
  • Flutter交互實(shí)戰(zhàn)-即刻App探索頁(yè)下拉&拖拽效果

    摘要:前言最近比較熱門,但是成體系的文章并不多,前期避免不了踩坑我這篇文章主要介紹如何使用實(shí)現(xiàn)一個(gè)比較復(fù)雜的手勢(shì)交互,順便分享一下我在使用過(guò)程中遇到的一些小坑,減少大家入坑作者鏈接先睹為快本項(xiàng)目支持運(yùn)行,效果如下對(duì)了,順便分享一下生成的小竅門,建 前言 Flutter最近比較熱門,但是Flutter成體系的文章并不多,前期避免不了踩坑;我這篇文章主要介紹如何使用Flutter實(shí)現(xiàn)一個(gè)比較復(fù)雜...

    wdzgege 評(píng)論0 收藏0
  • Flutter 開發(fā)實(shí)戰(zhàn)與前景展望 - RTC Dev Meetup

    摘要:穩(wěn)定性中大部分異常是不會(huì)引起應(yīng)用崩潰,更多會(huì)在上體現(xiàn)為紅色錯(cuò)誤堆棧,上異常等等。它是的實(shí)現(xiàn)類,實(shí)現(xiàn)跨幀保存的就是存放在這里,同時(shí)它也充當(dāng)了和之間的橋梁。一整塊的重繪區(qū)域,決定重繪的影響區(qū)域。手勢(shì)在手勢(shì)中引入了競(jìng)技的概念事件在中尤為重要。大家好,我是郭樹煜,Github GSY 系列開源項(xiàng)目的作者,系列包括有 GSYVideoPlayer 、GSYGitGithubApp(FlutterRea...

    _ipo 評(píng)論0 收藏0
  • Flutter 面試知識(shí)點(diǎn)集錦

    摘要:中的的線程是以事件循環(huán)和消息隊(duì)列的形式存在,包含兩個(gè)任務(wù)隊(duì)列,一個(gè)是內(nèi)部隊(duì)列,一個(gè)是外部隊(duì)列,而的優(yōu)先級(jí)又高于。同時(shí)還有處理按住時(shí)的事件額外處理,同時(shí)手勢(shì)處理一般在的子類進(jìn)行。谷歌大會(huì)之后,有不少人咨詢了我 Flutter 相關(guān)的問(wèn)題,其中有不少是和面試相關(guān)的,如今一些招聘上也開始羅列 Flutter 相關(guān)要求,最后想了想還是寫一期總結(jié)吧,也算是 Flutter 的階段復(fù)習(xí)。 ??系統(tǒng)完...

    andong777 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<