免费观看又色又爽又黄的小说免费_美女福利视频国产片_亚洲欧美精品_美国一级大黄大色毛片

flutter2教程,flutter20

Flutter 之 文件操作(二十九)

Dart的 IO 庫包含了文件讀寫的相關類,它屬于 Dart 語法標準的一部分,所以通過 Dart IO 庫,無論是 Dart VM 下的腳本還是 Flutter,都是通過 Dart IO 庫來操作文件的,不過和 Dart VM 相比,Flutter 有一個重要差異是文件系統路徑不同,這是因為Dart VM 是運行在 PC 或服務器操作系統下,而 Flutter 是運行在移動操作系統中,他們的文件系統會有一些差異。

為昭平等地區用戶提供了全套網頁設計制作服務,及昭平網站建設行業解決方案。主營業務為成都網站制作、做網站、外貿營銷網站建設、昭平網站設計,以傳統方式定制建設網站,并提供域名空間備案等一條龍服務,秉承以專業、用心的態度為用戶提供真誠的服務。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

Android 和 iOS 的應用存儲目錄不同, PathProvider 插件提供了一種平臺透明的方式來訪問設備文件系統上的常用位置。該類當前支持訪問兩個文件系統位置:

File代表一個整體的文件,他有三個構造函數,分別是:

文件讀取本身有兩種形式,一種是文本,一種是二進制。

2.2.1 讀取文本內容

如果是文本文件,File提供了readAsString、readAsLines、readAsStringSync、readAsLinesSync方法,讀取文本內容

readAsString 一次性讀取所有文本

readAsLines 一行行的讀取文本

結果返回的是一個List,list中表示文件每行的內容

readAsStringSync、readAsLinesSync同步讀取文本

2.2.2 讀取二進制內容

如果文件是二進制,那么可以使用readAsBytes或者同步的方法readAsBytesSync:

dart中表示二進制有一個專門的類型叫做Uint8List,他實際上表示的是一個int的List。

上面提到的讀取方式,都是一次性讀取整個文件,缺點就是如果文件太大的話,可能造成內存空間的壓力。

所以File為我們提供了另外一種讀取文件的方法,流的形式來讀取文件.

示例

dart提供了open和openSync兩個方法來進行隨機文件讀寫:

寫入和文件讀取一樣,可以一次性寫入或者獲得一個寫入句柄,然后再寫入。

一次性寫入的方法有四種,分別對應字符串和二進制

句柄形式可以調用openWrite方法,返回一個IOSink對象,然后通過這個對象進行寫入:

默認情況下寫入是會覆蓋整個文件的,但是可以通過下面的方式來更改寫入模式:

雖然dart中所有的異常都是運行時異常,但是和java一樣,要想手動處理文件讀寫中的異常,則可以使用try,catch:

我們還是以計數器為例,實現在應用退出重啟后可以恢復點擊次數。 這里,我們使用文件來保存數據:

1.引入PathProvider插件;在pubspec.yaml文件中添加如下聲明:

執行 flutter pub get

2.實現如下

參考:

Flutter開發--如何布局?

相對于iOS開發,Flutter的布局更具有靈活性,每個頁面設計都不一樣,相同頁面可選擇的布局方式也不一樣,如果單純的說應該如何去布局,我覺得不現實,大家可以參考下 Flutter官方的布局教程 。接下來,筆者,通過項目中的一個頁面,來一步一步的拆解布局的流程。整個過程,基本上按照拆解、組件封裝、具體布局這三步來的。

根據設計圖,可以看出整體可以分成兩部分,上面一部分是系統介紹模塊,下面一部分是真正的登錄內容,因為涉及到疊加,因此考慮用Stack;

系統介紹模塊部分:整體也是涉及到疊加,考慮用Stack,分為四部分。最底部漸變色背景用一個contanier,無須指定位置,全視圖擴展;載放logo圖標在上一層,用Image。最后兩個Text同級放在最上層。Image,Text各用Positioned包裹去指定位置。

登錄內容模塊是最外層是一個Contanier容器,去控制背景色和圓角。然后是一個Column元素,逐行排列。

第一行為Image,

第二行為Text,

第三行可以看成一個小Column,分兩塊進行布局

第四行可以看成一個小Column,分兩塊進行布局

第五行可以看作一個TextButton,

第六行可以看作一個Row,分三塊進行布局

通過上面這樣一步一步的分析后,基本上對大致的布局有了一個了解,最外層的控件大致選對(只要能實現的話,就是復雜度以及效率的問題),然后一步一步的拆解每一行的元素,如果有重復的或者覺得可以封裝出來的部分,則進行下一步。

每一行的拆解,大致也是按照這個思路來進行,因此筆者在這里就不做講解了。

在做到第三第四行的時候,發現這兩個很相似,而且設計到一些交互邏輯,筆者就想對第三第四行的這種展示進行封裝,覺得今后的布局可能會用到,因此在這一步,可以先把這一塊兒抽離出一個控件。利用TextField來實現這種輸入操作,具體的實現筆者不再詳細的描述了。

經過這一步,整體的規劃設計圖已經有了,各個組件也都有了,接下來的工作就是組裝了。

具體布局設計到一些細節的地方,例如整體Column的居中對齊(crossAxisAlignment)、間隔(Padding或Container包裹,筆者更喜歡用SizedBox占位)、居左居右居中(Align)、點擊事件(GestureDetector)以及圓角(BorderRadius)等一些特殊情況。

像第六行row是放在底部的,就可以在第六行前面增加一個Spacer()去填充空白區域。

對文字顏色大小等,可以用TextStyle直接設置。

對于輸入框的刪除按鈕,可以用Offstage這種Flutter特有的控制顯示隱藏的控件。

flutter項目升級2.0過程填坑記錄

在此之前先推薦看大佬的: 填坑指導

iOS需要注意:

1、flutter2.0要求cocoapods 升級到1.9.0

詳情看這篇博客

2、原來flutter項目中的podfile文件是舊版本的ccocoapods了,刪除podfile和對應的.lock,然后flutter項目重新運行使用它自動生成的podfile文件

3、安裝CocoaPods

卸載cocoapods:sudo gem uninstall cocoapods

查看cocoapods版本:pod --version

指定版本安裝:

sudo gem install -n /usr/local/bin cocoapods -v 1.9.3(新MacOS系統升級)

不指定版本安裝

sudo gem install -n /usr/local/bin cocoapods

說明 :老項目sdk1.17.0===升級到2.0.1,當前所有操作基于win平臺

到此為止環境已經準備妥當,正式進入項目修改。

所有的插件都要適配到空安全,插件是否支持均會有對應說明Null safety,適配過程不確定版本的話,可以使用dio: any,適配完事后再在pubspec.lock文件中查看具體的版本修改過來,實在有部分插件沒有支持的,參考下面

部分插件在適配空安全的版本放棄維護了,得自行更新或尋找替代,如: flutter_swiper 變為 flutter_swiper_null_safety ,插件更新后要注意項目中的用法是否需要更新

2.1.1: 以前采用的是 provide 插件共享全局數據,現在變化為 provider ,用法改變, 點擊參考 ,以防文章丟失,我重復一遍:

比如:

2.1.2: dio版本升級到4.0.0最新版后,部分用法改變

2.2.1

2.2.2

解決方案:

2.2.3

解決方案:

2.2.4

解決方案:

2.2.5

解決方案:

2.2.6

解決方案:

2.2.7

解決方案:

2.2.8

解決方案: child 換為sliver

2.2.8.1

解決方案: 項目目錄下: android--app-build.gradle --minSdkVersion改為:18 或者19

2.2.8.2

解決方案: 在pubspec.yarm管理里面添加:publish_to

2.2.8.3

解決方案: video_player升級后字段發生了變化,initialized字段更換為:isInitialized(_controller.value.isInitialized)

2.2.8.4

解決方案:

2.2.8.5

解決方案:

2.2.8.6

解決方案: 方案一:刪除ios目錄下的Podfile.lock 文件然后重新運行 pod install命令

方案二:刪除ios目錄下的Podfile.lock與Podfile文件 重新運行flutter run或flutter build ios

方案三:刪除ios目錄,重新運行 flutter create . 命令,注意有"."這個符號不要忘記

2.2.8.7

這個報錯一般對應的就是下面的報錯,注意看后面的報錯信息,看是哪個插件報錯。

解決方案: 把Podfile的版本注釋打開,改為platform :ios, '9.0' 或者是更高的版本

全局替換

1.將new List() 替換為[];

2.TextField的inputFormatters:[WhitelistingTextInputFormatter.digitsOnly] 替換為[FilteringTextInputFormatter.digitsOnly]

3.TextField的inputFormatters:[WhitelistingTextInputFormatter(RegExp("[a-z|A-Z|0-9]"))]替換為FilteringTextInputFormatter.allow(RegExp("[a-z|A-Z|0-9]"))

4.Stack組件中overflow: Overflow.visible改為 clipBehavior: Clip.none;overflow: Overflow.clip改為clipBehavior:Clip.hardEdge

5.ListWheelScrollView組件中clipToSize = false改為clipBehavior: Clip.none,clipToSize = true改為 Clip.hardEdge

6.TextField中maxLengthEnforced: true改為maxLengthEnforcement:MaxLengthEnforcement.enforced

7.FlatButton、RaisedButton、OutlineButton的變化: 官方參考

顏色的屬性發生了變化,由原來的Color 變為了MaterialStatePropertyColor, 這是未了解決不同狀態(pressed、hovered、focused、disabled)下按鈕顏色的變化

例如

8.出現如下警告

9.showSnackBar報錯誤

解決方案: Scaffold換為ScaffoldMessenger

10.textSelectionColor棄用

解決方案:

11.charts_flutter升級后屬性報錯

解決方案:

12.flutter 真機調試無法訪問網絡,dio報錯

解決方案:

android:

ios:

問題12完整參考

Flutter 零基礎入門實戰視頻教程(28 個視頻)

Flutter 零基礎入門實戰視頻教程 #01 環境搭建 「14:03」

Flutter 零基礎入門實戰視頻教程 #02 Dart 語言 「17:49」

Flutter 零基礎入門實戰視頻教程 #03 建立 Android studio 虛擬設備 「04:12」

Flutter 零基礎入門實戰視頻教程 #04 建立第一個項目 「08:23」

Flutter 零基礎入門實戰視頻教程 #05 安裝配置過程中可能遇到的問題(沒遇到者可以跳過) 「05:07」

Flutter 零基礎入門實戰視頻教程 #06 運行 iOS 模擬器 「04:07」

Flutter 零基礎入門實戰視頻教程 #07 Flutter 概述 「06:15」

Flutter 零基礎入門實戰視頻教程 #08 Scaffold AppBar 「Pro」「06:50」

Flutter 零基礎入門實戰視頻教程 #09 文檔和快捷鍵 「Pro」「02:36」

Flutter 零基礎入門實戰視頻教程 #10 顏色 Colors 「Pro」「05:47」

Flutter 零基礎入門實戰視頻教程 #11 自定義字體 fonts 「Pro」「05:09」

Flutter 零基礎入門實戰視頻教程 #12 hot reload StatelessWidget 「Pro」「04:56」

Flutter 零基礎入門實戰視頻教程 #13 使用圖片 「Pro」「04:59」

Flutter 零基礎入門實戰視頻教程 #14 使用圖標 - Icon 「Pro」「01:27」

Flutter 零基礎入門實戰視頻教程 #15 Button 按鈕使用指南 「Pro」「04:35」

Flutter 零基礎入門實戰視頻教程 #16 Container 和 Padding 「Pro」「04: 52」

Flutter 零基礎入門實戰視頻教程 #17 Row 「Pro」「05:24」

Flutter 零基礎入門實戰視頻教程 #18 Column 「Pro」「05:36」

Flutter 零基礎入門實戰視頻教程 #19 Flutter Outline Shortcuts 「Pro」「03:18」

Flutter 零基礎入門實戰視頻教程 #20 Expanded Widgets 「Pro」「06:06」

Flutter 零基礎入門實戰視頻教程 #21 實戰開始 「Pro」「11:42」

Flutter 零基礎入門實戰視頻教程 #22 換個編輯器 - Visual Studio Code 「Pro」「04:50」

Flutter 零基礎入門實戰視頻教程 #23 Stateful vs Stateless Widget 「Pro」「09:45」

Flutter 零基礎入門實戰視頻教程 #24 列表處理 「Pro」「04:54」

Flutter 零基礎入門實戰視頻教程 #25 自定義 class 「Pro」「05:37」

Flutter 零基礎入門實戰視頻教程 #26 card widget 「Pro」「04:26」

Flutter 零基礎入門實戰視頻教程 #27 Extracting Widgets 「Pro」「06:59」

Flutter 零基礎入門實戰視頻教程 #28 刪除 - Functions as Parameters - 完結 - 進入實戰課 「Pro」「04:35」

求flutter的教學視頻?。。?!

Flutter教程全套 (全網獨家)百度網盤免費資源在線學習 ?

鏈接:

提取碼: m9z8 ?

Flutter教程全套 (全網獨家)

第一套:Flutter 攜程17章全-整理好

第五套:Flutter高仿谷歌翻譯項目課程

第四套:兩小時掌握Flutter移動App開發視頻

第三套:flutter入門到精通全套

第七套:Flutter小實戰20個

第六套:仿直聘boss的flutter完整教程

第九套:Flutter跨平臺開發

第二套:flutter移動電商實戰-技術胖

第八套:Flutter基礎教程(基礎不好的優先看)

24Flutter的打包.mp4

23靜態資源和項目圖片的處理.mp4

22頁面跳轉并返回數據_.mp4

21導航的參數傳遞和接受-2_.mp4

20導航的參數傳遞和接受-1.mp4

新建一個flutter項目,可以在ios上運行,四步搞定!

1. 建立一個flutter項目的命令

2. 在ios文件夾下,生成pods文件夾

3. Xcode環境簽名設置;

把錯誤的版本刪除再添加,可解決簽名錯誤問題;必須先刪除再添加,直接修改可能不起作用。團隊開發,必須使用團隊的簽名。

4.運行創建的flutter項目;

選擇真機、模擬機,點擊運行按鈕,或使用命令運行:

下面兩步是贈送的:

5.新加一款插件,所涉及的命令;

ios 端所涉及的命令

6. 剛更新的插件和已有的插件有沖突怎么辦?

可以試一試以下步驟:

標題名稱:flutter2教程,flutter20
網頁網址:http://m.newbst.com/article24/dssiece.html

成都網站建設公司_創新互聯,為您提供網站設計公司、ChatGPT虛擬主機、用戶體驗、響應式網站、網站導航

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

外貿網站建設