【Flutter教程】從零構建電商應用(一)

在這個系列中,我們將學習如何使用google的移動開發框架flutter創建一個電商應用。本文是flutter框架系列教程的第一部分,將學習如何安裝Flutter開發環境并創建第一個Flutter應用,并學習Flutter應用開發中的核心概念,例如widget、狀態等。

本系列教程包含如下四個部分,敬請期待:

  1. 如何從零構建flutter應用
  2. 如何在flutter中布局元素
  3. 如何在flutter中組織數據
  4. 如何在flutter中展示數據

1. 開發環境安裝與Flutter項目創建

Flutter的開發文檔相當出色,請參考官方文檔先安裝開發環境。

一旦開發環境安裝好,我們可以創建一個新的測試項目。我傾向于使用android studio,因為它為flutter應用的開發提供了一個完備的集成開發環境。你需要在Android studio中安裝一個Dard語言插件。

現在啟動Android Studio,你會看到初始化Flutter項目的選項:

【Flutter教程】從零構建電商應用(一)

從配置列表中選擇Flutter Application

【Flutter教程】從零構建電商應用(一)

可以為你的第一個Flutter應用起一個酷炫的名字,不過如果你和我一樣不善于起名,就用timer好了。

【Flutter教程】從零構建電商應用(一)

對話框的最后一步,會要求我們填寫應用的包名:

【Flutter教程】從零構建電商應用(一)

接下來Flutter SDK就會為應用創建一個初始的目錄結構,main.dart是應用執行的入口。

【Flutter教程】從零構建電商應用(一)

2. 編寫并測試應用代碼

在Flutter中,一切都是控件(widget)。Flutter應用中的圖像、圖標和文本都是widget。布局元素例如行、列、柵格等用來安排其他widget的位置、大小和對齊,而這些布局元素本身也是widget。

參考如下代碼修改你的main.dart文件:

import 'package:flutter/material.dart';void main() => runApp(MyApp());class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(title: 'Welcome to Flutter',home: Scaffold(appBar: AppBar(title: Text('Welcome to Flutter'),),body: Center(child: Text('Hello World'),),),);}
}

現在啟動Android模擬器:

【Flutter教程】從零構建電商應用(一)

注意widget的焦點,我們接下來將修改MaterialApp的內容。先看一下原始版本:

body: Center(child: Text('Hello World'),
)

Flutter中的布局元素(也是widget)可以根據其是否支持包含多個widget,而簡單地歸類為兩種類型。例如,Container、Padding只能包含一個子widget,而Row、Column則可以包含多個。

現在我們在Row布局中引入三個文本widget:

body: Center(child: Row(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[Text('0'),Text('0'),Text('0'),],),
),

現在看起來是這樣:

【Flutter教程】從零構建電商應用(一)

在我們開始設置組件的樣式之前,建議先創建一個新的widget來處理樣式問題,以便遵循DRY(Don't Repeat Yoursel)原則。

將三個子widget用一個自定義widget(后面解釋)替換。現在main.dart文件變成:

import 'package:flutter/material.dart';void main() => runApp(MyApp());class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(title: 'Welcome to Flutter',home: Scaffold(appBar: AppBar(title: Text('Timer'),),body: Center(child: Row(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[CustomTextContainer(),CustomTextContainer(),CustomTextContainer(),],),),),);}
}class CustomTextContainer extends StatelessWidget {@overrideWidget build(BuildContext context) {return Text('00');}
}

我不是很擅長用戶界面,但是我們還是盡力吧,加點背景色,留點空白:

class CustomTextContainer extends StatelessWidget {CustomTextContainer({this.label, this.value});final String label;final String value;@overrideWidget build(BuildContext context) {return Container(margin: EdgeInsets.symmetric(horizontal: 5),padding: EdgeInsets.all(20),decoration: new BoxDecoration(borderRadius: new BorderRadius.circular(10),color: Colors.black87,),child: Column(mainAxisSize: MainAxisSize.min,children: <Widget>[Text('$value',style: TextStyle(color: Colors.white,fontSize: 54,fontWeight: FontWeight.bold,),),Text('$label',style: TextStyle(color: Colors.white70,),)],),);}
}

同時,在文本下面插入一個按鈕widget,修改后的代碼運行結果如下:

【Flutter教程】從零構建電商應用(一)

現在到了app最不可或缺的部分了:狀態。狀態將持有timer的當前值和運行標識。我
補充了一個TimerState類,它負責維護狀態,同時構建widget樹。

class Timer extends StatefulWidget {@overrideState<StatefulWidget> createState() {return new TimerState();}
}class TimerState extends State<Timer> {int secondsPassed = 0;bool isActive = false;@overrideWidget build(BuildContext context) {// Return Widget Tree}
}

按鈕用來切換timer的運行或者停止:

RaisedButton(child: Text(isActive ? 'STOP' : 'START'),onPressed: () {setState(() {isActive = !isActive;});},
)

Dart有個用于異步操作的優雅的模塊。我們可以使用其Timer類來實現讀秒。修改后的TimerAppState代碼如下,注意我們已經重構Timer類并改名為TimerApp以避免與異步模塊中的Timer類混淆:

class TimerAppState extends State<TimerApp> {static const duration = const Duration(seconds:1);int secondsPassed = 0;bool isActive = false;Timer timer;void handleTick() {if (isActive) {setState(() {secondsPassed = secondsPassed + 1;});}}@overrideWidget build(BuildContext context) {if (timer == null)timer = Timer.periodic(duration, (Timer t) {handleTick();});int seconds = secondsPassed % 60;int minutes = secondsPassed ~/ 60;int hours = secondsPassed ~/ (60*60);return MaterialApp(...)}
}

好了,我們已經完成了第一個Flutter應用,完整的Dard代碼可以在這里下載。

原文鏈接:【Flutter教程】從零構建電商應用(一)

匯智網翻譯整理,轉載請標明出處。

轉載于:https://blog.51cto.com/13697184/2329763

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/281304.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/281304.shtml
英文地址,請注明出處:http://en.pswp.cn/news/281304.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

為OWA自定義快捷鍵

這篇短文分享一下如何為自己常用的網頁添加自定義功能&#xff0c;例如添加快捷鍵。我這里用一個常用的網站作為范例。它是Outlook Web Access (OWA), 它的地址一般如下。我在寫郵件時希望能用一些快捷鍵來提高工作效率&#xff0c;但系統默認自帶的快捷鍵特別少&#xff0c;而…

數據結構 快速排序

快速排序是對冒泡排序的一種改進&#xff0c;是所有內部排序算法中平均性能最優的排序算法。其基本思想是基于分治法的&#xff1a;在待排序數組L[1...n]中任取一個元素pivot作為基準&#xff0c;從數組的兩端開始掃描。設兩個指示標志&#xff08;low指向起始位置&#xff0c;…

Finally語句塊的運行

一、finally語句塊是否一定運行&#xff1f; Java中異常捕獲機制try...catch...finally塊中的finally語句是不是一定會被運行&#xff1f;非常多人都說不是。當然他們的回答是正確的&#xff0c;經過試驗。至少下面有兩種情況下finally語句是不會被運行的&#xff1a; &#xf…

vue-cli 3.0 跨域請求代理

官方文檔中指明&#xff0c;跨域請求可以通過配置vue.config.js中的devServer.proxy選項來進行配置。 這個選項配置的本質實際上就是http-proxy-middleware中間件的用法&#xff0c;和Webpack-dev-server的proxy一樣。 vue-cli 3.0中介紹了兩種常見的用法&#xff1a; modul…

小米人員架構調整:組建中國區,王川任總裁

12月13日上午&#xff0c;小米內部發布人員調整公開信&#xff0c;信中傳達了兩個重要內容&#xff1a;將銷售與服務部改組為中國區&#xff0c;任命集團高級副總裁王川兼任中國區總裁。 在今年9月份&#xff0c;也就是小米上市前夕&#xff0c;雷軍在一封內部信中宣布對公司組…

在 .NET 7上使用 WASM 和 WASI

WebAssembly&#xff08;WASM&#xff09;和WebAssembly System Interface&#xff08;WASI&#xff09;為開發人員開辟了新的世界。.NET 開發人員在 Blazor WebAssembly 發布時熟悉了 WASM。Blazor WebAssembly 在瀏覽器中基于 WebAssembly 的 .NET 運行時上運行客戶端。WASI通…

Java基礎 五 方法

方法 1.1 方法概述 在我們的日常生活中&#xff0c;方法可以理解為要做某件事情&#xff0c;而采取的解決辦法。 如&#xff1a;小明同學在路邊準備坐車來學校學習。這就面臨著一件事情&#xff08;坐車到學校這件事情&#xff09;需要解決&#xff0c;解決辦法呢&#xf…

django rest framework 過濾 lim分頁

一.過濾 1.首先引用diango 自帶的過濾配置 2.導入模塊 from django_filters.rest_framework import DjangoFilterBackend from django_filters import rest_framework as filters 3.一種簡單的過濾: class BookView(ModelViewSet):queryset Book.objects.all()serializer_clas…

MySQL用戶及權限管理

MySQL用戶及權限管理查看用戶及權限查看用戶及作用域&#xff08;使用范圍&#xff09;查看用戶權限創建用戶及授權字段參數用戶管理使用命令提示符登錄MySQL mysql -h localhost -u root -p查看用戶及權限 mysql中的用戶信息和權限等都存儲在一個名為mysql的數據庫中。其中主…

附近有什么?8款可以查周邊的App

如今科技發達的時代&#xff0c;手機的功能不僅僅只是能通訊聊天&#xff0c;而是逐漸的走進了人們的生活中。因為有了APP&#xff0c;我們的生活才更豐富&#xff0c;并且有很多是我們生活中不可缺少的軟件&#xff0c;而這些軟件便是根據手機中的GPS定位系統而來的。簡單來說…

MyEclipse小問題與漢字處理

今天在使用MyEclipse時&#xff0c;遇到工作目錄報錯(如上圖)&#xff0c;解決方法如下&#xff1a;找到對應工作區(查看工作區的方法為&#xff1a;單擊File → Switch Workspace 即可)依次打開 .metadata文件夾 → .plugins文件夾 → org.eclipse.core.runtime文件夾 → .set…

關系數據庫設計及優化原則

一直以來就想總結一下自己這么多年來在關系數據庫上積累的經驗。奈何自己是一個比較懶的人一直不想動手去寫。扎克伯格曾說過&#xff1a;“想做一件事的話&#xff0c;最好的辦法就是先開始”。索性就先寫一點東西&#xff0c;這些東西不會太長&#xff0c;自然也不會包括太多…

java B2B2C springmvc mybatis電子商務平臺源碼-消息隊列之RocketMQ

RocketMQ出自阿里公司的開源產品&#xff0c;用 Java 語言實現&#xff0c;在設計時參考了 Kafka&#xff0c;并做出了自己的一些改進&#xff0c;消息可靠性上比 Kafka 更好。RocketMQ在阿里集團被廣泛應用在訂單&#xff0c;交易&#xff0c;充值&#xff0c;流計算&#xff…

VSCode同步設置

2022/4/1 更新 剛剛發現還有人在看這篇文章&#xff0c;這里更新一下&#xff0c;VSCode 從1.48版本開始已經內置了同步功能&#xff0c;可以不用再使用Settings Sync插件了。 點擊左下角的用戶或者設置的 Sign in to Sync Setting&#xff0c;使用GitHub或者Microsoft賬戶登…

配置三臺服務器組成的ELK集群(二)

上一篇里主要是介紹了ES和ES-Head的安裝過程&#xff0c;這一篇繼續介紹ELK集群的其他核心組件安裝過程。 五、安裝Logstash&#xff1a; 本案的Logstash安裝在10.113.130.117上&#xff1b;燃鵝&#xff0c;Logstash也可以利用多臺組成集群&#xff0c;如果未來單臺處理不過來…

Discuz X3.2源碼解析 discuz_application類(轉自百度)

discuz_application在/source/class/discuz/discuz_application.php中。 discuz_application繼承自抽象類discuz_base discuz_application主要實現對運行環境、配置、輸入、輸出、數據庫、設置、用戶、session、移動模塊、計劃任務、手機預覽等方面的初始化。 instance()函數來…

.NET性能優化-是時候換個序列化協議了

計算機單機性能一直受到摩爾定律的約束&#xff0c;隨著移動互聯網的興趣&#xff0c;單機性能不足的瓶頸越來越明顯&#xff0c;制約著整個行業的發展。不過我們雖然不能無止境的縱向擴容系統&#xff0c;但是我們可以分布式、橫向的擴容系統&#xff0c;這聽起來非常的美好&a…

Kubernetes-基于Helm安裝部署高可用的Redis

1、Redis簡介 Redis是一個開放源代碼&#xff08;BSD許可證&#xff09;的代理&#xff0c;其在內存中存儲數據&#xff0c;可以代理數據庫、緩存和消息。它支持字符串、散列、列表、集合和位圖等數據結構。Redis 是一個高性能的key-value數據庫&#xff0c; 它在很大程度改進了…

Vue 深度監聽和初始綁定

vue的監聽屬性普通方式無法監聽對象內部屬性的改變&#xff0c;并且初始化時不會監聽數據對象。 vue為監聽屬性提供了一種對象方法 watch: {option.size: {// handler為默認執行的方法handler (newValue, oldValue) {this.size newValue}&#xff0c;// 立即執行handler方法…

markdown流程圖畫法小結

markdown流程圖畫法小結markdown畫圖流程圖 最簡單的流程圖為例mermaid! graph TD A --> B //在沒有(),[].{}等括號的情況之下&#xff0c;圖標默認名字就是字母 A --> C C --> D B --> D 給圖標添加名字&#xff0c;改變只有矩陣圖形&#xff0c;在箭頭上添加文字…