[譯]看漫畫學Flux

来源:https://www.cnblogs.com/duyue6002/archive/2018/04/06/8728366.html
-Advertisement-
Play Games

原文地址: "A cartoon guide to Flux by Lin Clark" Flux在目前web開發中最受歡迎也較不被人理解,本文會以簡單易懂的方式解釋它。 出現問題 首先,我要聲明Flux所解決的基本問題。Flux是一種幫助你處理數據的模式。Flux和React都由Facebook開 ...


原文地址:A cartoon guide to Flux - by Lin Clark


Flux在目前web開發中最受歡迎也較不被人理解,本文會以簡單易懂的方式解釋它。

出現問題

首先,我要聲明Flux所解決的基本問題。Flux是一種幫助你處理數據的模式。Flux和React都由Facebook開發。許多人把他們放在一起用,當然你也可以單獨使用它們。它們的形成是為瞭解決Facebook所面臨的一系列典型問題。
這些問題中一個廣為人知的例子就是關於通知的錯誤(notification bug). 當你登錄Facebook時,你會通過消息圖標(message icon)看到一則通知(notification)。然而你點擊消息圖標後,可能根本沒有新消息,通知消失了。接著,在與網站進行幾次交互之後,通知又回來了。你再一次點擊消息圖標...依然沒有新消息。這個情況會在迴圈中繼續往複發生。

這不僅僅是發生在用戶里的迴圈,對於Facebook團隊里也會有這個迴圈。他們修複了錯誤,一切在一段時間里看似表現很好,接著錯誤又回來了。這一直處於解決問題和再次出現問題之間來回切換。

所以Facebook在尋找跳出死迴圈的方法。他們不想僅僅是修複一次bug,他們希望保證系統可預測,這樣他們就能確保問題不會重新出現。

根本問題

他們發現根本問題在於數據流經應用程式的方式。
住:這是我從他們的分享會上展示的簡化版本中收集到的,我確定實際的架構看起來並不一樣。
他們有保存數據的模型(Model),並將數據傳遞到視圖層(View Layer)渲染。
Model層將數據傳遞給View層
因為用戶交互發生在視圖層,視圖有時候需要根據用戶輸入來更新模型。有時模型還需要去更新其他的模型。最重要的是,這些行為有時會引發其他一系列的變化。我認為這非常有趣,因為你無法知道接下來會發生什麼!(作者此處用了比喻,I envision this as an edge-of-your-seat game of Pong — it’s hard to know where the ball is going to land (or fall off the screen))
視圖更新模型,模型接著更新其他模型
不考慮這些變化會引起非同步發生的可能性。一個變化可能會一起多種其他變化。我想這就好像拋出一袋乒乓球到乒乓游戲中,隨著他們飛過整個地方並穿過小徑。
總而言之,它使得調試數據流變得很困難。

解決方案:單向數據流

Facebook覺得嘗試一種不同的架構,數據向一個方向流動——只有一個方向——當你插入新數據時,這個流程就從頭重新開始。他們稱這一架構為Flux。
Facebook的Flux文檔中也有這張圖,而且比這裡要酷的多
實際上這個技術非常棒...但你可能無法從上面這張圖裡看出來。
一旦你理解了Flux,這張圖就顯得非常清晰。問題是如果你要找到對Flux完全新的文檔,我認為這張圖不能幫助你理解它...這就是圖應該做的事。在你開始深入瞭解如何做特定事情之前,圖會讓你對系統產生一個全面的瞭解。
幫助我更好理解Flux的不是這樣的圖,而是根據團隊中不同角色要實現共同目標來考慮這個系統。所以我會想你介紹我腦子裡的這些角色。

角色

在我將這些角色聯繫起來之前,我先對各個角色做簡單介紹。

行為創建者(Action)

第一個角色是這個行為創建者。他負責創建行為,這是所有改變和交互必須經歷的路徑。無論你是否想改變程式的狀態,或者讓視圖的渲染方式不同,你都需要創建行為。
我認為行為創建者就像電報員。他知道你想傳遞什麼消息,接著再以其他系統可以理解的方式格式化信息。
Action creator
行為創建者創建行為時,會伴隨一個type和一個payloadtype表示你在系統中定義為行為的類型之一(通常是常量列表),比如MESSAGE_CREATEMESSAGE_READ
讓系統的一部分知道所有可能的行為有一個很好的作用,那就是,當新人參與到項目里時,打開行為創建者的文件就能看到整個API——系統提供的所有可能的狀態改變。
一旦創建了行為消息,行為創建者就會將該行為傳遞給調度人員。

調度人員(Dispatcher)

調度人員有一個大的回調(callbacks)註冊表(registry),在某種程度上像電話交換機上的接線員,保留數據層(store)中需要發送的行為列表。當行為被行為創建者創建後,調度人員會將行為發送給不同的數據層。
調度人員以同步方式完成工作,如果你需要在數據層之間設置依賴關係,以便在其他數據層更新前更新,你可以讓調度人員使用waitFor()進行管理。
調度人員像一個總機操作員,知道所有不同數據層的回調
Flux的調度人員與其他很多架構中的不同。無論行為類型是什麼,它都會被髮送到所有的註冊數據層里。這意味著數據層不僅僅收到一些行為消息,而是接收全部消息再就實際情況過濾。

數據人員(Store)

接下來就是數據人員了。數據人員掌控這程式里所有的狀態,以及狀態的改變邏輯。
我把數據人員比喻成權力極大的爺,所有的狀態改變必須由他親自完成。你不能直接要求他改變狀態,要請求更改狀態,你必須遵循適當的步驟:通過行為創建者或調度人員提交行為。
數據人員是個爺
正如我之前提到的,如果一個數據層被調度人員註冊,所有的行為將會發送到那裡。在數據層里,數據人員一般會用一個switch語句查看行為類型,以決定這個數據層是否關心此行為。如果數據層關心此行為,那麼數據人員會根據這個行為找出需要做出哪些更改並更新狀態。
一旦數據人員改變了狀態,他就會提交一個改變事件,這會提示視圖控制員知道狀態變了。

視圖與視圖控制員(Controller view & view)

視圖負責拿到狀態並將其渲染出來給用戶看,以及接收用戶輸入。
視圖是一個展示者,他並不知道程式里發生任何事,只知道接收到的數據,以及如何將數據格式化成用戶能理解的方式(通過HTML)。
視圖控制員更像一個在數據人員和視圖之間的中層經理,數據人員告訴他狀態什麼時候變了,他收集到新狀態再將更新狀態發送給他的子視圖。
視圖與視圖控制員

他們怎麼一起工作

接下來看看這些角色怎麼共同工作的。

初始化(setup)

首先有個初始化:只發生一次的程式初始化。

  1. 數據員(stores)使得調度員(dispatcher)知道,無論何時有行為(action)來了,數據員需要被通知。
    1
  2. 視圖控制員(controller views)向數據員(stores)詢問最新狀態(state)。
  3. 當數據員向視圖控制員說明瞭狀態後,視圖控制員把這個狀態告訴其子視圖去渲染。
    2, 3
  4. 視圖控制員也告訴數據員當其狀態改變時記得通知自己。
    4

數據流(date flow)

一旦初始化完成後,程式就準備好接收用戶輸入。現在,我們假設用戶做改變引起了一個行為(action)。
我們通過用戶交互來啟動數據流。

  1. 視圖(view)告訴行為創建者(action creator)準備行為。
    1
  2. 行為創建者格式化行為併發送給調度員(dispatcher)。
    2
  3. 調度員按順序將行為發送給數據人員(store),每個數據員都收到了所有行為的提示,接著數據員篩選哪些是他關心的,再相應地改變數據層狀態(state)。
    3
  4. 一旦狀態改變,數據員就會讓當時需要他通知的那些視圖控制員知道其狀態變化。
  5. 這些視圖控制員會向數據員要他們更新後的狀態。
    4, 5
  6. 在數據員給了自己更新後的狀態,視圖控制員就會告訴其子視圖根據新狀態重新渲染。
    6

這就是我認為的Flux,希望對你有用!

譯者:如有翻譯錯誤,請指正喲,謝謝!(^U^)ノ~YO


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1)基礎 學習目的: 1. 客戶端表單驗證 2. 頁面動態效果 3. jQuery的基礎 什麼是JavaScript? 一種描述性語言,也是一種基於對象和事件驅動的,並具有安全性能的腳本語言 javaScript是一種基於對象和事件驅動的,並具有安全性能的腳本語言 解釋執行javaScript特點向 ...
  • 定義: 保證一個對象(類)僅有一個實例,並提供一個訪問它的全局訪問點; 實現原理: 利用閉包來保持對一個局部變數的引用,這個變數保存著首次創建的唯一的實例; 主要用於: 全局緩存、登錄浮窗等只需要唯一一個實例的時候; Part1、命名空間的管理員開發中經常會遇到不同的人定義的變數使用的單詞可能會重覆 ...
  • display的所有屬性 下麵就display的重要屬性進行講解,並配合一些相關的例子 基本屬性 display: none none 是 CSS 1 就提出來的屬性,將元素設置為none的時候既不會占據空間,也無法顯示,相當於該元素不存在。 該屬性可以用來改善重排與重繪,同時我也經常用它來做模態窗 ...
  • 使用遞歸函數必須要符合兩個條件: 1、 在每一次調用自己時,必須是(在某種意義上)更接近於解; 這句話怎麼理解? 大家家裡都有樓梯吧?比如從一樓走到二樓,那麼我們的起點是一樓,目的地是二樓,當你往上每走一個臺階是不是越接近二樓,也就是越接近目的地。 因此這句話可以這樣理解:函數每一次調用自己時... ...
  • 在 JavaScript 中 this 常常指向方法調用的對象,但有些時候並不是這樣的,本文將詳細解讀在不同的情況下 this 的指向。 一、指向 window: 在全局中使用 this,它將會指向全局對象,因為瀏覽器中運行的 JavaScript 的全局對象預設為 window, 所以,此時 ... ...
  • 背景 項目 :移動端H5電商項目 痛點 :慢!!! 初始方案 :最基本的圖片懶載入,靜態資源放到cdn,predns等等已經都做了。但是還是慢,慢在哪? 顯而易見的原因 :由於前後端分離,所有的數據都由介面下發,之後根據模板渲染頁面。也就是說,我們需要先載入js,等到js載入完畢之後,請求介面,介面 ...
  • 只要調用函數進行執行,都必須加括弧。 函數是一個對象,函數名是指向這個對象的指針。 函數名後面加上括弧就表示立即調用執行這個函數裡面的代碼。 使用不帶圓括弧的函數是訪問函數的指針,而非調用函數。 函數名後面加括弧,就直接執行函數返回值。 函數名後面不加括弧,表示函數名賦值給click等的事件,觸發c ...
  • 最近做小程式開發,出於練手,也是工作需要,就做了個微信小程式的類似於酒店預訂的日曆插件。先上圖; 這個插件分為上下兩部分,上邊是tab欄,會根據當前的日期自動定位到當前,並展示以後7天的日期,下邊為內容展示,隨tab欄變化而變化。思路:首先用`new Data()`時間對象初始化時間,獲取當前的日期 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...