為什么不要在?Flutter?中使用全局變量
前言
全局變量似乎是很棒的 Flutter 程序組件,因?yàn)樗鼈儽宦暶饕淮尾⑶铱梢员怀绦蛑械拿總€(gè)函數(shù)訪問。 但是,這些變量的成本比你想象的要高,主要是因?yàn)椋?/strong>
- 如果刪除一個(gè)全局變量,則必須搜索整個(gè)程序并重構(gòu)每個(gè)有權(quán)訪問已刪除全局變量的函數(shù)
- 它們很難測(cè)試,因?yàn)槟惚仨氃跍y(cè)試用例之間重置它們
- 很難跟蹤更改,因?yàn)槊總€(gè)函數(shù)都可以修改全局變量
以上所有原因都說明了為什么在 Flutter 中永遠(yuǎn)不應(yīng)該使用全局變量。 在本文中,我們將詳細(xì)了解全局變量的缺點(diǎn),并學(xué)習(xí)如何以更有效的方式管理狀態(tài)。
Flutter 中的全局變量是什么?
全局變量是公共變量,可以被 Flutter 程序中的每個(gè)方法和對(duì)象訪問。
全局變量是局部變量的替代品,它們?cè)诜椒ㄖ袆?chuàng)建并在該方法中訪問。
局部變量和全局變量之間的區(qū)別在于,局部變量不能被同一程序中的其他方法訪問——因此,與全局變量相比,局部變量的作用域是有限的。
Flutter 中使用全局變量的缺點(diǎn)
在 Flutter 中使用全局變量一直受到質(zhì)疑和批評(píng),通常被認(rèn)為是不好的做法。 以下是使用全局變量的缺點(diǎn):
1. 復(fù)雜的代碼維護(hù)過程
更改或刪除一個(gè)全局變量會(huì)觸發(fā)一系列事件,因?yàn)槭褂萌肿兞康男〔考头椒▽⑹艿接绊憽?/p>
如果要更改全局變量,則必須分析訪問全局變量的每個(gè)小部件將如何受到影響并進(jìn)行特定且必要的更改。
如果刪除一個(gè)全局變量,則必須搜索整個(gè)程序并重構(gòu)每個(gè)有權(quán)訪問已刪除全局變量的函數(shù)。
2. 全局變量使單元測(cè)試變得痛苦
如果你更改了一個(gè)具有全局變量的模塊,那么你將不得不為下一次測(cè)試重置它。
很難理解使用全局變量的遺留代碼,而理解程序流程是如何工作的更是難上加難。 很難有效地測(cè)試你不理解的代碼,調(diào)試也很困難,因?yàn)槟悴恢朗钦l改變了全局變量。
3. 全局變量導(dǎo)致“面條”代碼
由于程序中的每個(gè)函數(shù)都可以修改全局變量,因此很難跟蹤更改。 如果你正在構(gòu)建一個(gè)大型應(yīng)用程序,在 Flutter 中使用全局變量的情況會(huì)升級(jí)。 即使你正在構(gòu)建小型 Flutter 應(yīng)用程序,全局變量也會(huì)導(dǎo)致災(zāi)難。
4. 全局變量無法封裝
全局變量使得無法實(shí)現(xiàn)封裝,這是一種將代碼包裝到單個(gè)單元中的 OOP 概念。 封裝使得代碼的維護(hù)變得安全和容易。 如果你想有效地使用封裝,你必須禁止全局變量。
由于全局變量創(chuàng)建了“面條”代碼,因此需要大量的規(guī)范來約束它們。 但是,有些開發(fā)人員會(huì)使用全局變量,因?yàn)樗麄冊(cè)谝粋€(gè)小團(tuán)隊(duì)中,并且在某些情況下不利于更改。
但是,無論應(yīng)用程序的大小如何,當(dāng)需要維護(hù)代碼時(shí),全局變量都會(huì)帶來挑戰(zhàn)。 如果有必要使用全局變量,至少使它們不可變。
在下一部分中,你將學(xué)習(xí)狀態(tài)管理庫和包,它們提供了以更好的方式管理變量狀態(tài)的更好方法,而不會(huì)影響維護(hù)過程。
如何以更好的方式管理狀態(tài)
Flutter 是一個(gè)跨平臺(tái)的動(dòng)態(tài)框架,用于收集和處理來自用戶的數(shù)據(jù)。
從開關(guān)到單選按鈕,必須有效地管理數(shù)據(jù)狀態(tài)。 但是,全局變量會(huì)增加應(yīng)用程序數(shù)據(jù)流的復(fù)雜性。 全局變量使數(shù)據(jù)很容易發(fā)生變異,這可能會(huì)導(dǎo)致處理從用戶那里收集的數(shù)據(jù)時(shí)出現(xiàn)混亂。
provider 等狀態(tài)管理包可用于緩解全局變量帶來的問題。 以下是可用于管理狀態(tài)的狀態(tài)包管理器和庫的列表:
1. Provider 狀態(tài)管理包
Provider 狀態(tài)管理器包被廣泛用于收集小部件狀態(tài)數(shù)據(jù)并在狀態(tài)更改時(shí)更新小部件。
使用提供程序時(shí),只有受影響的小部件會(huì)在數(shù)據(jù)發(fā)生突變時(shí)被更新。 與隨處變化的全局變量相比,Provider 降低了復(fù)雜性。 Provider 從小部件收集數(shù)據(jù)并監(jiān)聽小部件周圍發(fā)生的數(shù)據(jù)變化。
該包將應(yīng)用程序狀態(tài)與 UI 分離,Provider 促進(jìn)應(yīng)用程序維護(hù)和測(cè)試。
使用以下代碼片段添加和使用 Provider 包插件:
dependencies:
flutter:
sdk: flutter
provider: ^3.1.0Provider 程序包還允許你與多個(gè)類共享小部件狀態(tài):
void main() {
runApp(
MultiProvider(
providers: [
ChangeNotifierProvider(create: (context) => CartModel()),
Provider(create: (context) => SomeOtherClass()),
],
child: const MyApp(),
),
);
}2. GetX
GetX 是一個(gè)輕量級(jí)的 Flutter 庫,它提高了可擴(kuò)展性,因?yàn)樗试S你解耦視圖、依賴注入、表示層和依賴注入。
它提供以下功能:
- 狀態(tài)管理
- 依賴注入
- 導(dǎo)航
- 路由管理
如果你正在尋找一個(gè)節(jié)省資源且消耗最少的庫,GetX 是你的最佳選擇。
要在 Flutter 應(yīng)用程序啟動(dòng)中開始使用 GetX,請(qǐng)將 get 添加到你的 pubspec.yaml 文件中:
dependencies: get:
接下來,導(dǎo)入使用 GetX 庫函數(shù)和組件時(shí)需要的 get 文件:
import 'package:get/get.dart';
3. Riverpod
Riverpod 類似于 `provider——唯一的區(qū)別是它以單向方式分發(fā)數(shù)據(jù)。
此狀態(tài)管理器確保你的代碼可測(cè)試且易于閱讀,因?yàn)樗擞糜诮M合對(duì)象的嵌套。 特殊功能是它在編譯過程中檢測(cè)錯(cuò)誤。 這將節(jié)省你的時(shí)間,因?yàn)槟銓⒃谶\(yùn)行時(shí)將缺陷添加到你的應(yīng)用程序之前修復(fù)錯(cuò)誤。
4. Redux
Redux 是一個(gè)庫,可幫助你有效地管理小部件的數(shù)據(jù)狀態(tài)。 Redux 是一種以單向方式跨小部件執(zhí)行狀態(tài)數(shù)據(jù)分布的架構(gòu)。 該庫很棒,因?yàn)樗藸顟B(tài)重復(fù),你可以測(cè)試狀態(tài)結(jié)果是否為真。
5. SetState 方法
之前,我們只介紹了管理狀態(tài)的 Flutter 包和庫。
當(dāng)你的小部件更改數(shù)據(jù)值時(shí),可以調(diào)用一個(gè)名為 setState 的方法。 它將導(dǎo)致 UI 根據(jù)新狀態(tài)發(fā)生變化。 你可以添加在狀態(tài)更改時(shí)執(zhí)行某些操作的代碼。 下面是 Flutter 中 setState 的基本實(shí)現(xiàn):
class _MyHomePageState extends State<MyHomePage> {
int _counter = 0;
void _incrementCounter() {
_counter++;
setState(() {});
}總結(jié)
本文我們?cè)敿?xì)了解了全局變量是什么以及為什么我們不應(yīng)該在 Flutter 中使用它們。 此外,我們還探索了可用于更有效地管理狀態(tài)的各種狀態(tài)管理庫。
到此這篇關(guān)于為什么不要在 Flutter 中使用全局變量的文章就介紹到這了,更多相關(guān)Flutter 全局變量內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android自定義SeekBar滑動(dòng)顯示數(shù)字
這篇文章主要為大家詳細(xì)介紹了Android自定義SeekBar滑動(dòng)顯示數(shù)字,使用FrameLayout結(jié)合SeekBar滑動(dòng)時(shí),數(shù)值顯示,滑動(dòng)停止時(shí)顯示數(shù)字,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
Android入門之Fragment嵌套Fragment的用法詳解
這篇文章主要為大家詳細(xì)介紹了Android中如何實(shí)現(xiàn)Fragment嵌套Fragment的相關(guān)資料,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下2023-02-02
android實(shí)現(xiàn)音樂跳動(dòng)效果的示例代碼
這篇文章主要介紹了android實(shí)現(xiàn)音樂跳動(dòng)效果的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04
Android實(shí)現(xiàn)viewpager實(shí)現(xiàn)循環(huán)輪播效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)viewpager實(shí)現(xiàn)循環(huán)輪播效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-03-03
Android ViewFlipper的詳解及實(shí)例
這篇文章主要介紹了Android ViewFlipper的詳解及實(shí)例的相關(guān)資料,通過本文希望能幫助大家理解這部分內(nèi)容,需要的朋友可以參考下2017-08-08

