Umi 項(xiàng)目實(shí)踐

項(xiàng)目背景

Teams 開始做工業(yè)級的安防監(jiān)控軟件厅翔。主要的需求是通過安防設(shè)備以及傳感器獲取相應(yīng)區(qū)域的參數(shù)信息,在Gateway 上做數(shù)據(jù)處理后上報(bào)給服務(wù)端,在云端進(jìn)行數(shù)據(jù)聚合分析形成特定的模型,從不同的切面來監(jiān)測區(qū)域和人身安全劈愚。

作為公司的大前端團(tuán)隊(duì),web 部分的技術(shù)棧主要是Angular( angular 2+)闻妓。由于要采用公司內(nèi)部的UI 庫菌羽,需要采用React 作為前端的開發(fā)技術(shù)棧。后來經(jīng)過對現(xiàn)在市面上的框架的調(diào)研纷闺,決定采用Umi算凿。

為什么是Umi

Umi 是螞蟻金服的底層前端框架,已經(jīng)在阿里的業(yè)務(wù)中大量使用過犁功,有足夠多的項(xiàng)目作為技術(shù)實(shí)踐和打磨氓轰。

簡單理解:Umi = Dva + 配置式/約定式路由 + 大量webpck插件

umi 的實(shí)現(xiàn)業(yè)務(wù)的核心部分主要還是dva。
dva 是基于redux 和 redux-sage(異步解決方案)的數(shù)據(jù)流方案浸卦,其中還內(nèi)置了react-router 和fetch, 是一個(gè)輕量級的應(yīng)用框架署鸡。

dva: https://dvajs.com/
dva 入門教程: https://github.com/dvajs/dva-docs/tree/master/v1/zh-cn/tutorial

為什么是Typescript

由于Team 之前的前端技術(shù)棧是Angular, Ts 已經(jīng)深入人心了。靜態(tài)類型約束和TSlint 給予的類型檢測限嫌,讓代碼更利于閱讀靴庆,基本的引用及語法錯(cuò)誤大大減少。

Team對于使用ts的基本要求是:
1怒医、Components中必須要有props 和state 的接口聲明以及對應(yīng)參數(shù)的類型約束炉抒。參數(shù)的類型約束可以不用非常明確(可以采用any 或者{[key:string]: any})的約束方式。
2稚叹、models 中對于復(fù)雜的數(shù)據(jù)結(jié)構(gòu)焰薄,需要拆解結(jié)構(gòu)類型。保證model 在引用時(shí)扒袖,能夠明確清楚其完整的結(jié)構(gòu)以及數(shù)據(jù)類型塞茅。
3、function 對入?yún)⒑统鰠⒂忻鞔_的類型標(biāo)識(shí)季率。
4野瘦、work space 不能有任何的Ts lint 的標(biāo)紅語法報(bào)錯(cuò)。

基于Umi的業(yè)務(wù)框架

項(xiàng)目迭代了一年多了飒泻,team 對umi 使用的有了一些積累鞭光。后面的項(xiàng)目都會(huì)采用相同的技術(shù)架構(gòu)。我們再已運(yùn)行的項(xiàng)目上抽象出公共的結(jié)構(gòu)泞遗,形成我們team的基礎(chǔ)業(yè)務(wù)框架衰猛,主要包括:
1、configure router刹孔,我們需要根據(jù)不同的用戶形成不同的路由視圖啡省,在原在umi原本的路由基礎(chǔ)上,再做配置髓霞。
2卦睹、Advance component,項(xiàng)目中采用的公司內(nèi)部的組件庫方库,并不能完全滿足我們的業(yè)務(wù)需求结序,我們會(huì)在其基礎(chǔ)上再做封裝。
3纵潦、Utils徐鹤,每個(gè)項(xiàng)目中積累的工具函數(shù)是我們一直維護(hù)的工具包垃环,將會(huì)形成無依賴的工具庫。
4返敬、Local遂庄,基于umi 的local 插件,使用python 腳本處理excel 表格生成對應(yīng)js 文件劲赠。
5涛目、Draggable configuration dashboard,基于React-grid-layout基礎(chǔ)上再封裝凛澎,可拖拽可變尺寸霹肝,可配置的動(dòng)態(tài)dashboard。

未來

Umi 框架的在項(xiàng)目中的應(yīng)用已經(jīng)相對成熟塑煎,將來我們會(huì)將基于的umi 的業(yè)務(wù)框架抽象出來后沫换,以一種類似git subLirbrary 形式進(jìn)行管理。多個(gè)項(xiàng)目啟動(dòng)時(shí)采用基礎(chǔ)的項(xiàng)目結(jié)構(gòu)最铁,公共的結(jié)構(gòu)和共享的部分共同維護(hù)苗沧。當(dāng)多個(gè)項(xiàng)目迭代到一定程度之后,會(huì)生成大量的符合公司design language 的組件庫炭晒,反饋給公司的組件設(shè)計(jì)和開發(fā)部門待逞,形成一個(gè)良性循環(huán)。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末网严,一起剝皮案震驚了整個(gè)濱河市识樱,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌震束,老刑警劉巖怜庸,帶你破解...
    沈念sama閱讀 212,718評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異垢村,居然都是意外死亡割疾,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,683評論 3 385
  • 文/潘曉璐 我一進(jìn)店門嘉栓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宏榕,“玉大人,你說我怎么就攤上這事侵佃÷橹纾” “怎么了?”我有些...
    開封第一講書人閱讀 158,207評論 0 348
  • 文/不壞的土叔 我叫張陵馋辈,是天一觀的道長抚芦。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么叉抡? 我笑而不...
    開封第一講書人閱讀 56,755評論 1 284
  • 正文 為了忘掉前任尔崔,我火速辦了婚禮,結(jié)果婚禮上褥民,老公的妹妹穿的比我還像新娘季春。我一直安慰自己,他們只是感情好轴捎,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,862評論 6 386
  • 文/花漫 我一把揭開白布鹤盒。 她就那樣靜靜地躺著蚕脏,像睡著了一般侦副。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上驼鞭,一...
    開封第一講書人閱讀 50,050評論 1 291
  • 那天秦驯,我揣著相機(jī)與錄音,去河邊找鬼挣棕。 笑死译隘,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的洛心。 我是一名探鬼主播固耘,決...
    沈念sama閱讀 39,136評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼词身!你這毒婦竟也來了厅目?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,882評論 0 268
  • 序言:老撾萬榮一對情侶失蹤法严,失蹤者是張志新(化名)和其女友劉穎损敷,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體深啤,經(jīng)...
    沈念sama閱讀 44,330評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拗馒,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,651評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了溯街。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片诱桂。...
    茶點(diǎn)故事閱讀 38,789評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖呈昔,靈堂內(nèi)的尸體忽然破棺而出访诱,到底是詐尸還是另有隱情,我是刑警寧澤韩肝,帶...
    沈念sama閱讀 34,477評論 4 333
  • 正文 年R本政府宣布触菜,位于F島的核電站,受9級特大地震影響哀峻,放射性物質(zhì)發(fā)生泄漏涡相。R本人自食惡果不足惜哲泊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,135評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望催蝗。 院中可真熱鬧切威,春花似錦、人聲如沸丙号。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,864評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽犬缨。三九已至喳魏,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間怀薛,已是汗流浹背刺彩。 一陣腳步聲響...
    開封第一講書人閱讀 32,099評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留枝恋,地道東北人创倔。 一個(gè)月前我還...
    沈念sama閱讀 46,598評論 2 362
  • 正文 我出身青樓瘦陈,卻偏偏與公主長得像瀑志,于是被迫代替她去往敵國和親帆啃。 傳聞我的和親對象是個(gè)殘疾皇子艘蹋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,697評論 2 351