《思念》-汪國(guó)真 〈yearn〉-Wang Guozhen
創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:成都做網(wǎng)站、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的城關(guān)網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!
思念 Yearn
我叮嚀你的 What I've baden you,
你說 不會(huì)遺忘 you said,its never gotta be sank into oblivion
你告訴我的What You've told me ,
我也 全都珍藏i also, shall always treasure them all
對(duì)于我們來(lái)說 To us
記憶是飄不落的日子 Memories are like the persistent days
——永遠(yuǎn)不會(huì)發(fā)黃 will never turn yellowing
相聚的時(shí)候 總是很短 At the time of togetherness,its always so short
期待的時(shí)候 總是很長(zhǎng)At the time of expectation,its always so long
歲月的溪水邊The Stream side of the years
撿拾起多少閃亮的詩(shī)行has picked up countless twinkling stich
如果你要想念我 Once if you expect to miss me
就望一望天上那 Do look up
閃爍的繁星 at those glittery stars heavenly!
有我尋覓你的 (coz)inside is my sight seeking for you
目——光 imaginative-------ness
譯:留學(xué)語(yǔ)言學(xué)者---顧瓊雯
在網(wǎng)上找了很多沒有關(guān)于這方面的例子,組件之間傳值,可以通過構(gòu)建函數(shù),如果我要回調(diào)這個(gè)組件的值呢,給大家介紹一下這兩個(gè)值?ValueChanged?VoidCallback 自己也加深記憶一下
一ValueChanged
官方解釋
這個(gè)值可以回調(diào)值,例如
二?VoidCallback?
這個(gè)值也可以回調(diào)但不能回調(diào)值,只能觸發(fā)方法
hao((){
print("");
});
hao(VoidCallback voidCallback){
voidCallback();
}
錯(cuò)誤方法下面會(huì)報(bào)錯(cuò)的
emotional flutter
感情的浮動(dòng)
笑顏(えがお)殘(のこ)る 帰(かえ)り道(みち)に
いつかなくした 聲(こえ)探(さが)してる
歸途中,殘留著你的笑容
尋找著,曾幾何時(shí)的聲音
記憶(きおく)の暗(やみ)が刻(きざ)む時(shí)(とき)
今(いま)も終(お)わらなくて
烙印在黑暗中的記憶
那一刻始終無(wú)法沒滅
空(そら)の中(なか)舞(ま)い降(お)りる
白(しろ)い羽(はね) 揺(ゆ)らして
舞動(dòng)潔白的雙翼
從空中飄舞而降
手(て)を伸(の)ばし 駆(か)け抜(ぬ)け
あなたの影(かげ) 追(お)いかけていく
出雙手,奔向前方
追尋著你熟悉的身影
白(しろ)い雪(ゆき)が降(ふ)り積(つ)もれば
包(つつ)み隠(かく)すの 悲(かな)しみの色(いろ)
皚皚的白雪從天而降
為我掩蓋悲傷的色彩
心(こころ)の奧(おく)に潛(ひそ)む愛(あい)
どうか憶(おぼ)えていて
將我心底潛藏的愛
毫無(wú)保留的獻(xiàn)予你
空(そら)高(たか)く舞(ま)い上(あ)がる
白(しろ)い羽(はね) 広(ひろ)げて
舒展?jié)嵃椎碾p翼
輕舞飛揚(yáng)于廣闊的天際
柔(やわ)らかな陽(yáng)(ひ)の中(なか)
あなたの夢(mèng)(ゆめ)みていたい
在柔和的陽(yáng)光里
滿懷著你的夢(mèng)想
遠(yuǎn)(とお)く空(そら) 舞(ま)い踴(おど)る
白(しろ)い羽(はね) 纏(まと)って
身披潔白的雙翼
翩翩起舞于悠遠(yuǎn)的天空
ふたつの手(て) 重(かさ)ねて
未來(lái)(みらい)を離(はな)さないでいて
我們的雙手緊緊牽系
把握住未來(lái),請(qǐng)不要放手
與iOS的ViewController、Android的Activity一樣,F(xiàn)lutter中的Widget也存在生命周期,并且通過State來(lái)提現(xiàn)。而App則是一個(gè)特殊的Widget,除了需要處理視圖顯示的各個(gè)階段,還需要應(yīng)對(duì)應(yīng)用從啟動(dòng)到退出所經(jīng)歷的各個(gè)狀態(tài)。
State的生命周期,指的是在用戶參與的情況查下,其關(guān)聯(lián)的Widget所經(jīng)歷的從創(chuàng)建到顯示再到更新最后到停止,直至銷毀的各個(gè)過程階段。
這些不同的階段涉及到的特定的任務(wù)處理,正確理解State的生命周期至關(guān)重要,State的生命周期流程圖圖,如下所示:
從圖中可以看到,State的生命周期可以分為3個(gè)階段:創(chuàng)建、更新、銷毀。下面將介紹每一個(gè)階段的具體流程
State初始化時(shí)會(huì)依次執(zhí)行:構(gòu)造方法 - initState - didChangeDependencies - build,隨后完成頁(yè)面渲染
Widget的狀態(tài)更新,主要由3個(gè)方法觸發(fā):setState、didChangeDependencies與didUpdateWidget。
一旦這三個(gè)方法被調(diào)用,F(xiàn)lutter就回銷毀舊的Widget,并調(diào)用build方法重建Widget
組件銷毀相對(duì)比較簡(jiǎn)單,組件被移除,或者頁(yè)面銷毀的時(shí)候,系統(tǒng)會(huì)調(diào)用deactivate和dispose這兩個(gè)方法來(lái)移除或銷毀組件
下面這張表格也可以幫助我們理解記憶這些調(diào)用實(shí)際
視圖的生命周期,定義了視圖的加載到構(gòu)建的全過程,其回調(diào)機(jī)制能夠確保我們可以更具視圖的狀態(tài)選擇合適的時(shí)間做恰當(dāng)?shù)氖虑?,而App的生命周期,則定義了App從啟動(dòng)到退出的全過程
在原生Android、iOS開發(fā)中,有時(shí)我們需要再對(duì)應(yīng)的App生命周期事件中做相應(yīng)的處理,比如App從后臺(tái)進(jìn)入前臺(tái),從前臺(tái)退出后臺(tái),或者在UI繪制完成后做一些處理。
這樣的需求,在原生開發(fā)中,可以通過重寫Activity、ViewController生命周期回調(diào)方法,或者是注冊(cè)應(yīng)用程序的相關(guān)通知來(lái)兼容App的生命周期并做相應(yīng)的處理。而在Flutter中,我們可以利用WidgetsBindingObserver類,來(lái)實(shí)現(xiàn)同樣的需求。
下面我們看看WidgetsBindingObserver中具體有哪些回調(diào)函數(shù):
didChangeAppLifecycleState回調(diào)函數(shù)中,有一個(gè)參數(shù)類型為AppLifecycleState的枚舉類型,這個(gè)枚舉類型是Flutter對(duì)App生命周期狀態(tài)的封裝,它的常用狀態(tài)包括:
可以將App切前后臺(tái),控制臺(tái)輸出的App狀態(tài),可以發(fā)現(xiàn):
我們可以通過下面的這張圖直觀的了解狀態(tài)切換過程
除了需要監(jiān)聽App的生命周期回調(diào)做相應(yīng)處理外,根據(jù)不同的需求,我們需要再組件宣講之后做一些與顯示安全相關(guān)的操作,在iOS中,可以通過GCD的方法,讓操作在下一個(gè)RunLoop執(zhí)行,在Android中,可以通過View.post()插入消息隊(duì)列,來(lái)保證在組件渲染后進(jìn)行相關(guān)操作。在Flutter中實(shí)現(xiàn)同樣的需求會(huì)更簡(jiǎn)單:使用WidgetsBinding來(lái)實(shí)現(xiàn)即可
WidgetsBinding提供了單詞Frame繪制回調(diào)和實(shí)時(shí)Frame繪制回調(diào)兩種機(jī)制來(lái)滿足不同的需求場(chǎng)景: