成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

React為什么需要Flux-like的庫

wangtdgoodluck / 958人閱讀

摘要:的關(guān)鍵構(gòu)成梳理了一下,需要配合的庫去使用,是因?yàn)橐鉀Q通信問題。還有各個(gè)事件之間,有可能存在依賴關(guān)系,事件后,也觸發(fā)。相比于傳統(tǒng)的事件系統(tǒng),融入了不少的思想。中,將會是最大的門檻之一。

從學(xué)習(xí)React到現(xiàn)在的一點(diǎn)感受

我覺得應(yīng)該有不少同學(xué)和我一樣,上來學(xué)React,覺得甚是驚艷,看著看著,發(fā)現(xiàn)facebook 安利了一個(gè)flux,圖畫的巨復(fù)雜,然后各種例子都有用這個(gè)東西,沒辦法,硬著頭皮看??吹盟贫嵌?,然后突然大家又都推薦Redux,號稱最簡單的flux-like的實(shí)現(xiàn),結(jié)果實(shí)現(xiàn)的源碼是很簡單,但是文檔是源碼的幾十倍,概念甩一臉,寫個(gè)簡單東西,要建十幾個(gè)文件,寫得云里霧里。

有沒有想到,為什么要用Flux這類東西?本篇的定位是讓大家知道有個(gè)脈絡(luò),所以不會太注意措辭的準(zhǔn)確性.

React的數(shù)據(jù)流向

React只是一個(gè)view層的解決方案,光有界面沒用,還得加上數(shù)據(jù)才行。React通過propsstate去渲染界面,所以有個(gè)很形象的描述UI = f(props,state).

有數(shù)據(jù),就有數(shù)據(jù)通信的問題。react是單向數(shù)據(jù)流,父組件通過props把數(shù)據(jù)傳遞給子組件。但是數(shù)據(jù)的流向不可能只有這一種。

祖父組件到孫子組件。
這個(gè)看上去只是父到子的衍生,但是祖祖祖父到孫子組件呢。這個(gè)react在(好像是)0.13時(shí)通過context基本解決了,關(guān)于context,之前沒接觸的同學(xué),可以看文檔

子到父。下面是一種方案:父給子傳遞一個(gè)函數(shù),子在只要調(diào)用這個(gè)函數(shù),父就能得到相關(guān)的數(shù)據(jù)。但是孫子到祖祖祖父呢。。

非父子關(guān)系:基本可以叫做是兄弟關(guān)系,以網(wǎng)頁為例,總歸有一個(gè)共同的祖先,但是有可能是非常非常遠(yuǎn)的兄弟。這個(gè)怎么處理。

組件的一些關(guān)系和相應(yīng)的通信方式,官方有簡單的說明,見文檔

對于上面的23兩點(diǎn),用react本事的機(jī)制,寫出來都很別扭,特別是第3點(diǎn)。兩個(gè)不相關(guān)的地方,要數(shù)據(jù)通信,最簡單就是一個(gè)全局變量嗎。當(dāng)然光有全局變量還不行,你改了全局變量,其他所有對這個(gè)變量感興趣React組件的都要被通知到,這樣才能相應(yīng)改變界面。你如果接觸到設(shè)計(jì)模式,應(yīng)該能想到觀察者模式(中介者模式也可以,實(shí)際上flux更像中介者中,不過觀察者應(yīng)該接受度更高點(diǎn),而且這里不影響理解)。

其實(shí)官方文檔中,也有些小線索。

For communication between two components that don"t have a parent-child relationship, you can set up your own global event system. Subscribe to events in componentDidMount(), unsubscribe in componentWillUnmount(), and call setState() when you receive an event. Flux pattern is one of the possible ways to arrange this.

這段的關(guān)鍵是you can set up your own global event system。所以你只要去研究以前各種事件系統(tǒng)是怎么設(shè)計(jì),就可以自己擼一套 **ux了。

**UX的關(guān)鍵構(gòu)成

梳理了一下,React需要配合Flux-Like的庫去使用,是因?yàn)橐鉀Q通信問題。通信的關(guān)鍵有一下幾點(diǎn):

數(shù)據(jù),這個(gè)不用說的吧。因?yàn)閞eact中,通過setState去觸發(fā)改變界面,命名成state

各種事件,叫event可能更直觀,但是大家都叫它action,一個(gè)意思,發(fā)生了一個(gè)動(dòng)作。這個(gè)動(dòng)作有一下幾個(gè)關(guān)鍵屬性:什么動(dòng)作,誰發(fā)出的(這個(gè)我看各個(gè)類flux庫中,好像都沒處理),有沒有額外信息嗎。

事件發(fā)生,要分發(fā)出去,包括改變數(shù)據(jù),然后通知給所有監(jiān)聽數(shù)據(jù)變化的Listeners

注冊監(jiān)聽者。

這些都是大家能想象到。好了,根據(jù)這幾點(diǎn),一個(gè)簡單的Myux就可以寫了

class Myux{
    state:{},
    actionTypes:{},
    dispatch(){},
    subscribe(){}
    listeners:[]
}

與上面四個(gè)組成部分項(xiàng)對應(yīng)。來個(gè)例子吧,以計(jì)數(shù)器為例吧。

class CountStore{
    static actionTypes:{
        UP:"UP", //你英語好,你用increase
        DOWN:"DOWN"
    }
    
    state:0 //數(shù)據(jù),計(jì)數(shù)開始是零
    listeners:[]
    
    dispatch(actionType){
        if(actionType === CountStore.actionTypes.UP){
            this.state++;
        }
        if(actionType === CountStore.actionTypes.DOWN){
            this.state--;
        }
        this.listeners.forEach((ln)=>{
            ln(actionType,this,undefined)//對應(yīng)什么動(dòng)作,誰發(fā)出的,額外信息。
        })
    }
    
    subscribe(ln){
        this.listeners.push(ln)
        //返回一個(gè)函數(shù),調(diào)用,就取消注冊
        return ()=>{
            const index = this.listeners.indexOf(ln);
            if(index !== -1){
                this.listeners.splice(index,1)
            }
        }
    }
}

react的組件里,只要注冊成listener,然后state發(fā)生變化,被通知到,調(diào)用setState進(jìn)行視圖更新就好。

class CountComponent extends React.Component{
    constructor(props,context){
        super(props,context)
        const store = this.props.store;
        this.state = store.getState();
        
    }
    
    componentDidMount(){
        this.unsubscribe = store.subscribe((actionType,store)=>{
            if(this.state !== store.getState()){
                this.setState(store.getState());
            }
        })
    }
    
    componentWillUnmount(){
        if(typeof this.unsubscribe === "function"){
            this.unsubscribe();
        }
    }
    
    
    render(){
        const state = this.state
        return 
{state}
} }

使用嗎,直接mount到body上,會報(bào)warning,忽略...

const countStore = new CountStore()
ReactDOM.render(
    ,
    document.body
)

這樣,只要在任何地方,countStore.dispatch(upOrDown),CountComponent里的數(shù)字就會加加減減。
可以想想一下,如果頁面有2,3個(gè)組件要根據(jù)計(jì)數(shù)器的數(shù)值,做界面的相應(yīng)變化,都是可以輕松滿足的。

當(dāng)然,如果只有一個(gè)組件用需要這個(gè)store,那么單純代碼上,這樣寫,要多寫很多東西。但是誰知道以后頁面不會加一個(gè)要共用這個(gè)store的組件,這時(shí)候這個(gè)store就是組件間通信的法寶了。

實(shí)際情況要復(fù)雜

上面只有一個(gè)store,這是store還只有一個(gè)state,這個(gè)太簡單了。實(shí)際,你的應(yīng)用可能要維護(hù)多個(gè)狀態(tài)。怎么辦

一個(gè)store里一個(gè)state,然后多個(gè)store

    ListStore => ListState
    DetailStore => DetailState

全局就一個(gè)store,state是一個(gè)狀態(tài)樹,整個(gè)應(yīng)用需要的state,都在這個(gè)樹里。

    GlobalStore => state:{list:[],detail:{}} //...
    

還有一個(gè)問題dispatch,是全局一個(gè)dispatch,還是每個(gè)store一個(gè)dispatch。

這些分歧,加上函數(shù)式等,就導(dǎo)致了有flux,reflux,redux。。

還有各個(gè)事件之間,有可能存在依賴關(guān)系,A事件后,B也觸發(fā)。又要加waitFor中間件等概念。不過整體來說,就這些東西。

各種庫特點(diǎn)大串燒 redux的特點(diǎn)

redux的文檔里,有三大原則,有了上面的概念,我們來對照看一下

Single source of truth:就是更改應(yīng)用一個(gè)state tree,儲存在一個(gè)store里,這種情況,也只能有一個(gè)dispatch

State is read-only:state是全局的,如果不是只讀的,很難維護(hù)。這個(gè)上面沒有體現(xiàn),但是也是很自然的想法。

Mutations are written as pure functions:這個(gè)算redux最大的特點(diǎn),引入了reducers的概念,和第二點(diǎn)有相輔相成的感覺。

另外還有中間件系統(tǒng)。2、3兩點(diǎn),其實(shí)是函數(shù)式編程的基本概念,不變量pure function。相比于傳統(tǒng)的事件系統(tǒng),Redux融入了不少functional reactive programming(FRP)的思想。

flux的特點(diǎn)

單dispatch,多store多state,用waitFor處理store的依賴。

reflux

多dispatch,多store多state。這個(gè)并沒實(shí)際用過,看文檔,應(yīng)該是這樣的。有問題,請?zhí)岢觥?/p> 后記

現(xiàn)在有種趨勢,傳統(tǒng)的事件系統(tǒng)逐漸讓大家覺得low b,functional reactive programming(FRP)高大上。
Redux有一些FRP的思想,被大家覺得比Flux高大上,但是不是很復(fù)雜的項(xiàng)目,應(yīng)該會有:臥槽,那么簡單的東西,為毛有那么多文件,寫得那么繞的感覺。

angular2中,RxJS將會是最大的門檻之一。

我覺得把,從能解決問題的復(fù)雜度上,F(xiàn)RP的確比傳統(tǒng)的事件系統(tǒng)高級,但是概念也更多,不是特復(fù)雜的程序,這些概念只會增加你的開發(fā)難度,并且對后面維護(hù)的人要求更高。

Java那么多年,沒RxJava,服務(wù)器端,android端,那么多年也挺過來了,雖然先進(jìn),不一定合適。我們現(xiàn)在自己的項(xiàng)目,使用的就是自己擼的一個(gè)小東西。對我們現(xiàn)在的規(guī)模,開發(fā)和維護(hù)都挺好的。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/86184.html

相關(guān)文章

  • 專治前端焦慮的學(xué)習(xí)方案

    摘要:不過今天我希望能夠更進(jìn)一步,不僅僅再抱怨現(xiàn)狀,而是從我個(gè)人的角度來給出一個(gè)逐步深入學(xué)習(xí)生態(tài)圈的方案。最后,我還是想提到下對于的好的學(xué)習(xí)方法就是回顧參照各種各樣的代碼庫,學(xué)習(xí)人家的用法與實(shí)踐。 本文翻譯自A-Study-Plan-To-Cure-JavaScript-Fatigue。筆者看到里面的幾張配圖著實(shí)漂亮,順手翻譯了一波。本文從屬于筆者的Web Frontend Introduc...

    codeGoogle 評論0 收藏0
  • React 升級:Redux

    摘要:正如我們前面的教程所提到的,在組件之間流通數(shù)據(jù)更確切的說,這被叫做單向數(shù)據(jù)流數(shù)據(jù)沿著一個(gè)方向從父組件流到子組件。這就是如何使數(shù)據(jù)流變得更簡單的原因。它是一種傾向單向數(shù)據(jù)流比如的設(shè)計(jì)模式。這是因?yàn)榭偸墙邮芎头祷貭顟B(tài)用來更新。 前言 近期接觸React項(xiàng)目,學(xué)到許多新知識點(diǎn),網(wǎng)上教程甚多,但大多都把知識點(diǎn)分開來講,初學(xué)者容易陷入學(xué)習(xí)的誤區(qū),摸不著頭腦,本人在學(xué)習(xí)中也遇到許多坑。此篇文章是筆...

    garfileo 評論0 收藏0
  • 14個(gè)最好的 JavaScript 數(shù)據(jù)可視化庫

    摘要:適用于,演示這是開發(fā)的一個(gè)簡單的可視化庫,它允許你創(chuàng)建所有常用的圖表類型條形圖,樹形圖,折線圖,面積圖等??梢暂p松地對折線圖和條形圖進(jìn)行混合和匹配以組合不同的數(shù)據(jù)集,這是非常棒的功能。 翻譯:瘋狂的技術(shù)宅原文:https://www.monterail.com/blo... 本文首發(fā)微信公眾號:jingchengyideng歡迎關(guān)注,每天都給你推送新鮮的前端技術(shù)文章 你的程序有多...

    Mertens 評論0 收藏0
  • 精讀《12 個(gè)評估 JS 庫你需要關(guān)心的事》

    摘要:大公司廣泛使用的開源庫,并且有一定國際影響力,而且大廠也有成功開源歷史經(jīng)驗(yàn)的話,就會增加說服力??偨Y(jié)下次技術(shù)選型討論時(shí),可以拿出規(guī)則一條一條比對了然后技術(shù)選型只是基礎(chǔ)庫,利用這些基礎(chǔ)可以維護(hù)好自己的開源庫,把更多時(shí)間用在創(chuàng)造業(yè)務(wù)價(jià)值上。 1 引言 作者給出了從 12 個(gè)角度全面分析 JS 庫的可用性,分別是: 特性。 穩(wěn)定性。 性能。 包生態(tài)。 社區(qū)。 學(xué)習(xí)曲線。 文檔。 工具。 發(fā)...

    junbaor 評論0 收藏0
  • 一個(gè)治愈 JavaScript 疲勞的學(xué)習(xí)計(jì)劃

    摘要:只是抱怨事物的狀態(tài)并沒有什么卵用,我打算給你一個(gè)實(shí)實(shí)在在的一步一步征服生態(tài)圈的學(xué)習(xí)計(jì)劃。好消息是,這剛好是本學(xué)習(xí)計(jì)劃關(guān)注的問題。比如,一個(gè)不錯(cuò)的出發(fā)點(diǎn)是的課。是一個(gè)由創(chuàng)建和開源的庫。我個(gè)人推薦的初學(xué)者課程。而個(gè)人項(xiàng)目是嘗試新技術(shù)的完美時(shí)機(jī)。 本文轉(zhuǎn)載自:眾成翻譯譯者:網(wǎng)絡(luò)埋伏紀(jì)事鏈接:http://www.zcfy.cc/article/1617原文:https://medium.fr...

    jhhfft 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<