亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Flutter中如何實(shí)現(xiàn)無Context跳轉(zhuǎn)詳解

 更新時(shí)間:2019年09月06日 14:06:02   作者:入魔的冬瓜  
這篇文章主要給大家介紹了關(guān)于Flutter中如何實(shí)現(xiàn)無Context跳轉(zhuǎn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Flutter具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

背景介紹

Navigator.of(context).push(MaterialPageRoute(builder: (context){
   return DemoPage();
  }));

在日常的項(xiàng)目開發(fā)中,我們一般push一個(gè)新頁面是用上面的方法的,利用Navigator.of(context)來進(jìn)行push或者pop操作。

缺點(diǎn):這種情況是必須傳context的,目的是為了利用Navigator.of(context)來獲取到NavigatorState對(duì)象,然后才能進(jìn)行push或者pop操作。

那如果我要實(shí)現(xiàn)在項(xiàng)目的任何地方都可以push一個(gè)新頁面的話,而這個(gè)地方有可能獲取不到context,所以這個(gè)時(shí)候,就需要實(shí)現(xiàn)無context跳轉(zhuǎn)。

解決方案

無context跳轉(zhuǎn),本質(zhì)就是不必要我們每次都去傳context參數(shù),然后利用一些操作直接去獲取到當(dāng)前的NavigatorState。

方案1:利用GlobalKey

  • 在Flutter中,利用GolbalKey利用獲取到對(duì)應(yīng)Widget的State對(duì)象。所以,這里,我們可以通過一個(gè)GlobalKey的key值,來獲取到NavigatorState對(duì)象。
  • MaterialApp中包裝了WidgetsApp,而WidgetsApp包裝了Navigator,并且將 Navigator的key屬性作為navigatorKey暴露出來了。所以,我們可以通過設(shè)置navigatorKey,然后利用這個(gè)key去獲取到NavigatorState對(duì)象。

這里貼一下相關(guān)的源碼,具體的大家可以自己去看源碼。

MaterialApp類:

WidgetsApp類:可以看出,我們定義的navigatorKey,最后是會(huì)傳給Navigator的key值,所以我們?cè)谕饷婢涂梢酝ㄟ^key.currentState()方法來獲取到這里的NavigatorState對(duì)象了。

class _WidgetsAppState extends State<WidgetsApp> implements WidgetsBindingObserver {

 GlobalKey<NavigatorState> _navigator;

 void _updateNavigator() {
 _navigator = widget.navigatorKey ?? GlobalObjectKey<NavigatorState>(this);
 }
 
 @override
 Widget build(BuildContext context) {
 Widget navigator;
 if (_navigator != null) {
  navigator = Navigator(
  key: _navigator,
  initialRoute: WidgetsBinding.instance.window.defaultRouteName != Navigator.defaultRouteName
   ? WidgetsBinding.instance.window.defaultRouteName
   : widget.initialRoute ?? WidgetsBinding.instance.window.defaultRouteName,
  onGenerateRoute: _onGenerateRoute,
  onUnknownRoute: _onUnknownRoute,
  observers: widget.navigatorObservers,
  );
 }
}

簡(jiǎn)單的代碼實(shí)現(xiàn)

1、定義一個(gè)GlobalKey< NavigatorState>對(duì)象

 static GlobalKey<NavigatorState> navigatorKey=GlobalKey();

2、創(chuàng)建MaterialApp的對(duì)象的時(shí)候,將navigatorKey賦值給MaterialApp。

MaterialApp(
   navigatorKey: Router.navigatorKey,
)

使用GlobalKey在任意地方獲取NavigatorState對(duì)象

navigatorKey.currentState.pushNamed("/login");

方案2:利用NavigatorObserver

  • NavigatorObserver,看這名字,就知道是可以用來監(jiān)聽Navigator的變化。比如當(dāng)push一個(gè)新頁面的時(shí)候,Navigator會(huì)監(jiān)聽到NavigatorState發(fā)生變化,回調(diào)didPush()方法。

注意:NavigatorObserver里面定義了一個(gè)NavigatorState對(duì)象navigator,所以我們可以通過自定義NavigatorObserver,然后直接利用這個(gè)navigator對(duì)象來做頁面push或者pop操作,這樣的話,我們就不用自己去利用context去獲取navigatorState對(duì)象了。


MaterialApp類,提供了navigatorObservers屬性,這樣我們就可以自定義NavigatorObserver去監(jiān)聽Navigator的變化。

NavigatorState類,執(zhí)行instState對(duì)象的時(shí)候,會(huì)將自身賦值到監(jiān)聽的所有observer對(duì)象的_navigator里面。


簡(jiǎn)單的代碼實(shí)現(xiàn)

1、自定義NavigatorObserver。

class CustomNavigatorObserver extends NavigatorObserver{
 static CustomNavigatorObserver _instance;

 static CustomNavigatorObserver getInstance() {
 if (_instance == null) {
  _instance = CustomNavigatorObserver();
 }
 return _instance;
 }
}

2、創(chuàng)建MaterialApp的對(duì)象的時(shí)候,將CustomNavigatorObserver賦值給MaterialApp

MaterialApp(
   navigatorObservers: [CustomNavigatorObserver()],
)

3、使用CustomNavigatorObserver在任意地方進(jìn)行頁面操作

CustomNavigatorObserver.getInstance().navigator.pushNamed("/login");

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • 關(guān)于Android bitmap你不知道的一些事

    關(guān)于Android bitmap你不知道的一些事

    這篇文章主要為大家詳細(xì)介紹了關(guān)于Android bitmap你不知道的一些事,使用bitmap需要注意的一些細(xì)節(jié),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Android Camera變焦編程步驟

    Android Camera變焦編程步驟

    這篇文章主要介紹了Android Camera變焦編程步驟,本文講解了添加Camera權(quán)限、判斷是否支持變焦、修改焦距等步驟,并分別給出了操作代碼,需要的朋友可以參考下
    2015-04-04
  • android LabelView實(shí)現(xiàn)標(biāo)簽云效果

    android LabelView實(shí)現(xiàn)標(biāo)簽云效果

    這篇文章主要為大家詳細(xì)介紹了android LabelView實(shí)現(xiàn)標(biāo)簽云效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Android編程實(shí)現(xiàn)WebView自適應(yīng)全屏方法小結(jié)

    Android編程實(shí)現(xiàn)WebView自適應(yīng)全屏方法小結(jié)

    這篇文章主要介紹了Android編程實(shí)現(xiàn)WebView自適應(yīng)全屏方法,結(jié)合實(shí)例形式總結(jié)了三種常用的WebView自適應(yīng)全屏實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-12-12
  • Android?十六進(jìn)制狀態(tài)管理實(shí)例詳解

    Android?十六進(jìn)制狀態(tài)管理實(shí)例詳解

    這篇文章主要為大家介紹了Android?十六進(jìn)制狀態(tài)管理實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • android圖像繪制(三)畫布刷屏問題記錄

    android圖像繪制(三)畫布刷屏問題記錄

    在canvas中繪制動(dòng)態(tài)圖的時(shí)候,如果使用了一個(gè)固定的背景圖片,只有一個(gè)小小的精靈在移動(dòng)!這樣的情況下卻不得不在沒幀中重新繪制背景圖片,使得效率降低,本文章只是記錄一下,并不是解決方法感興趣的朋友可以了解下
    2013-01-01
  • Android金額輸入框只允許輸入小數(shù)點(diǎn)后兩位效果

    Android金額輸入框只允許輸入小數(shù)點(diǎn)后兩位效果

    實(shí)現(xiàn)android 金額輸入框輸入小數(shù)點(diǎn)后兩位的效果也不是很復(fù)雜,只需要設(shè)置輸入框輸入的字符類型、設(shè)置InputFilter、設(shè)置輸入變化監(jiān)聽即可。這篇文章主要介紹了Android金額輸入框只允許輸入小數(shù)點(diǎn)后兩位 ,需要的朋友可以參考下
    2017-05-05
  • flutter日期選擇器 flutter時(shí)間選擇器

    flutter日期選擇器 flutter時(shí)間選擇器

    這篇文章主要為大家詳細(xì)介紹了flutter日期選擇器,flutter時(shí)間選擇器,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • Android AIDL實(shí)現(xiàn)與服務(wù)相互調(diào)用方式

    Android AIDL實(shí)現(xiàn)與服務(wù)相互調(diào)用方式

    這篇文章主要介紹了Android AIDL實(shí)現(xiàn)與服務(wù)相互調(diào)用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • Android手勢(shì)操作簡(jiǎn)單實(shí)例講解

    Android手勢(shì)操作簡(jiǎn)單實(shí)例講解

    這篇文章主要為大家詳細(xì)介紹了Android手勢(shì)操作簡(jiǎn)單實(shí)例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09

最新評(píng)論