快速應(yīng)用開(kāi)發(fā),你真的知道嗎?(快速應(yīng)用開(kāi)發(fā),你真的知道嗎英文)
▲ 題圖
什么是 RAD ?
快速應(yīng)用程序開(kāi)發(fā)(RAD)是一種專(zhuān)注于設(shè)計(jì)和原型設(shè)計(jì)階段的開(kāi)發(fā)方法,目的是獲得用戶(hù)的即時(shí)反饋。與先進(jìn)行初始計(jì)劃再進(jìn)一步執(zhí)行的傳統(tǒng)開(kāi)發(fā)模型不同,RAD 有著更多的靈活性。通過(guò)快速增量更新和即時(shí)用戶(hù)反饋的不斷迭代,使得最終能獲得更好的產(chǎn)出結(jié)果。
詹姆斯·馬?。↗ames Martin)于 1991 年定義了快速應(yīng)用程序開(kāi)發(fā)(RAD)的模型,提供了除瀑布式開(kāi)發(fā)過(guò)程之外的另一種開(kāi)發(fā)過(guò)程。經(jīng)典的瀑布方式能完美地適應(yīng)建筑領(lǐng)域和其他一些行業(yè),這些行業(yè)中,需求范圍一般很少變動(dòng),且變動(dòng)的代價(jià)非常高。例如,如果開(kāi)始建造一座橋梁,則不可能在完成一半時(shí)將其改建成一條渡輪。
相反,軟件的開(kāi)發(fā)過(guò)程卻是比較靈活的。對(duì)同一業(yè)務(wù)需求的解決方案通常不止一個(gè),且變換解決方案的成本較低。因此,基于瀑布式的詳細(xì)設(shè)計(jì)和提前規(guī)劃通常會(huì)輸給快速試錯(cuò)的開(kāi)發(fā)方式,還有,站在用戶(hù)的角度,往往只有在看到具體的產(chǎn)品時(shí),才能有思路并提供更好的反饋。
快速應(yīng)用程序開(kāi)發(fā)方法論的核心是從費(fèi)時(shí)費(fèi)力的計(jì)劃工作轉(zhuǎn)移到快速建立產(chǎn)品的原型上來(lái)。具體來(lái)說(shuō),RAD 模型將軟件開(kāi)發(fā)過(guò)程分為四個(gè)階段:
▲ RAD 流程
- 需求計(jì)劃
在此階段,用戶(hù)和項(xiàng)目團(tuán)隊(duì)一起確定目標(biāo)系統(tǒng)未來(lái)要達(dá)到的目標(biāo)。主要關(guān)注于需要實(shí)現(xiàn)的業(yè)務(wù)目標(biāo),對(duì)于需求的嚴(yán)謹(jǐn)性沒(méi)有太多要求。在原型設(shè)計(jì)階段快速調(diào)整業(yè)務(wù)目標(biāo)及需求的能力是關(guān)鍵。
- 用戶(hù)設(shè)計(jì)
用戶(hù)設(shè)計(jì)是快速應(yīng)用程序開(kāi)發(fā)方法的核心部分,是與瀑布模型相區(qū)別的關(guān)鍵點(diǎn)。這時(shí),開(kāi)發(fā)人員開(kāi)始構(gòu)建系統(tǒng)原型。目標(biāo)是通過(guò)最快、成本最低的方式給用戶(hù)提供一些可演示的內(nèi)容。原型產(chǎn)品可以只滿(mǎn)足一部分需求,或者只覆蓋少數(shù)場(chǎng)景,并且,在代碼編寫(xiě)時(shí),也可以抄近路。
在原型準(zhǔn)備好后,會(huì)拿給用戶(hù)演示。開(kāi)發(fā)團(tuán)隊(duì)盡可能收集所有的反饋,這里,原始需求會(huì)不可避免地發(fā)生改變:紙上似乎正確的東西在應(yīng)用程序中可能完全不同。根據(jù)這些反饋,開(kāi)發(fā)人員會(huì)重新修改原型,直到用戶(hù)對(duì)結(jié)果感到滿(mǎn)意。
- 軟件開(kāi)發(fā)
現(xiàn)在我們已經(jīng)確切地知道了需要完成的內(nèi)容。開(kāi)始進(jìn)行實(shí)質(zhì)性地開(kāi)發(fā)并測(cè)試,以便按期交付產(chǎn)品。這個(gè)階段不能再走捷徑了,需要關(guān)注產(chǎn)品的質(zhì)量、可伸縮性、可維護(hù)性等等。并且,用戶(hù)會(huì)一直參與對(duì)產(chǎn)品進(jìn)行反饋,直到開(kāi)發(fā)的最后階段。在快速應(yīng)用程序開(kāi)發(fā)的周期的這個(gè)階段,仍然可以接收需求的一些小調(diào)整。
根據(jù)我們選擇的開(kāi)發(fā)工具和其他因素,我們?cè)谠O(shè)計(jì)階段開(kāi)發(fā)的原型可能會(huì)直接廢棄不用。
- 部署上線
這是最后階段,包括驗(yàn)收測(cè)試、產(chǎn)品上線和用戶(hù)培訓(xùn)。
快速應(yīng)用程序開(kāi)發(fā)的優(yōu)缺點(diǎn)
RAD 將天平從可預(yù)測(cè)性?xún)A向至敏捷性,這樣會(huì)帶來(lái)一些正面和負(fù)面的影響。
- 優(yōu)點(diǎn)
- 高質(zhì)量
有了用戶(hù)在原型階段的深度參與,最終的完成的系統(tǒng)能更加貼合他們的需求,用戶(hù)的滿(mǎn)意度相對(duì)較高。
- 降低風(fēng)險(xiǎn)和成本
使用瀑布式開(kāi)發(fā)方法,用戶(hù)只能在項(xiàng)目交付時(shí)看到結(jié)果并提供反饋。在這一階段如果再進(jìn)行需求變更,將會(huì)費(fèi)錢(qián)又費(fèi)力。而使用 RAD 方法時(shí),在原型階段用戶(hù)已經(jīng)參與對(duì)成型的產(chǎn)品提供反饋,此時(shí)修改后面的需求開(kāi)銷(xiāo)不大。
- 缺點(diǎn)
- 缺乏可擴(kuò)展性
RAD 開(kāi)發(fā)模型需要開(kāi)發(fā)團(tuán)隊(duì)與最終用戶(hù)之間的緊密合作。當(dāng)團(tuán)隊(duì)太大或利益相關(guān)者太多時(shí),原型制作過(guò)程不可避免地會(huì)變慢。如果每個(gè)人都參與,對(duì)變更需求的頻繁討論也變得非常困難。因此,RAD 被認(rèn)為是中小型團(tuán)隊(duì)的最佳選擇。
- 軟件設(shè)計(jì)不佳
在原型設(shè)計(jì)階段偏重于特定的業(yè)務(wù)功能和走捷徑的做法有時(shí)會(huì)導(dǎo)致整個(gè)解決方案設(shè)計(jì)不佳。
- 前期難以控制
顯然,在項(xiàng)目完成原型開(kāi)發(fā)階段之前,是無(wú)法對(duì)項(xiàng)目范圍、預(yù)算和時(shí)間進(jìn)行預(yù)測(cè)。不過(guò),仍然可以基于需求計(jì)劃階段的結(jié)果來(lái)確定一個(gè)大概的預(yù)期。
- 對(duì)用戶(hù)依賴(lài)大
RAD 方法假設(shè)用戶(hù)在項(xiàng)目生命周期的所有階段都要參與,特別是需要深度了解需求的業(yè)務(wù)專(zhuān)家的參與,而他們通常是是公司中最忙的人。
RAD vs. Agile
如果你知道敏捷開(kāi)發(fā),此時(shí),你也許覺(jué)得,快速應(yīng)用程序開(kāi)發(fā)與敏捷開(kāi)發(fā)似乎是一樣的?
RAD 這個(gè)術(shù)語(yǔ)的出現(xiàn)比敏捷早 10 年,而且也同樣使用了迭代的方法,所以通常被認(rèn)為是敏捷開(kāi)發(fā)的前身。但事實(shí)上,RAD 是一種具體的方法論,而敏捷則涉及到哲學(xué)立場(chǎng),不僅僅指軟件開(kāi)發(fā)。所以公平一點(diǎn)說(shuō),RAD 與 Scrum、 KanBan、 TDD 等開(kāi)發(fā)方法一樣,都屬于敏捷軟件開(kāi)發(fā)方法學(xué)的內(nèi)容。
我的項(xiàng)目能用 RAD 嗎?
如上所述,RAD 無(wú)法在嚴(yán)苛的環(huán)境中使用,例如:
- 需要預(yù)先知道預(yù)算和開(kāi)發(fā)時(shí)間表
- 用戶(hù)無(wú)法定期參與或者用戶(hù)不想過(guò)多消耗時(shí)間和精力
- 項(xiàng)目范圍大,參與團(tuán)隊(duì)多,利益相關(guān)者多
大型企業(yè)或政府組織的項(xiàng)目通常滿(mǎn)足這些特點(diǎn)。但是,即使在這種情況下,也可以使用一些 RAD 的理念。例如,對(duì)于固定價(jià)格的項(xiàng)目,可以分割一部分預(yù)算用于原型和需求變更;如果有客戶(hù)愿意參與,則將原型的范圍限定在需求最難以確定的部分。
而另一方面,對(duì)于中小型企業(yè)或部門(mén)內(nèi)的項(xiàng)目,則使用 RAD 會(huì)非常有效。在這些項(xiàng)目中,業(yè)務(wù)人員自己控制預(yù)算并且對(duì)項(xiàng)目成果非常用心。非常典型的例子就是各種業(yè)務(wù)線(LOB)應(yīng)用系統(tǒng),指的是業(yè)務(wù)流程自動(dòng)化或者為了更有效地運(yùn)行特定業(yè)務(wù)而開(kāi)發(fā)的應(yīng)用系統(tǒng)。
同樣,對(duì)于創(chuàng)建網(wǎng)站這種項(xiàng)目來(lái)說(shuō),RAD 也非常適合。這種項(xiàng)目一般規(guī)模不大,涉及的相關(guān)人員也不多,但是需要他們盡早地參與,因?yàn)樵O(shè)計(jì)這個(gè)東西,是非常主觀的,每個(gè)人的想法都不一樣!
快速應(yīng)用開(kāi)發(fā)的工具
RAD 方法論的成功很大程度上依賴(lài)于快速地出原型以及緊密的協(xié)作,因此,選擇合適的工具非常重要。
設(shè)計(jì)與原型制作
例如:Figma、Balsamiq、Invision、Sketch、Adobe XD。
使用諸如 Figma 和 InVision 之類(lèi)的快速應(yīng)用程序開(kāi)發(fā)工具,圖形設(shè)計(jì)師和用戶(hù)體驗(yàn)專(zhuān)家能夠快速完成原型,為用戶(hù)提供完整的設(shè)計(jì)和可點(diǎn)擊操作的原型來(lái)收集他們的反饋。一旦原型的某個(gè)迭代版本獲得用戶(hù)的認(rèn)可,就可以將項(xiàng)目導(dǎo)出為前端開(kāi)發(fā)人員可重用的格式,從而進(jìn)入實(shí)質(zhì)性的開(kāi)發(fā)階段。這些工具主要用于創(chuàng)建網(wǎng)站,但也可以為更復(fù)雜的應(yīng)用系統(tǒng)或用戶(hù)界面設(shè)計(jì)用戶(hù)體驗(yàn)和原型。
▲ 使用 Figma 進(jìn)行設(shè)計(jì)
其他的一些工具,比如 Balsamiq,主要是業(yè)務(wù)分析師使用。通過(guò)簡(jiǎn)單的線框圖設(shè)計(jì)業(yè)務(wù)原型,而漂亮的最終設(shè)計(jì)通常在后期完成。這類(lèi)工具對(duì)于具有復(fù)雜用戶(hù)交互功能的大型系統(tǒng)是不錯(cuò)的選擇。
▲ 使用 Balsamiq 創(chuàng)建原型
軟件開(kāi)發(fā)
現(xiàn)階段,軟件開(kāi)發(fā)仍然是創(chuàng)建應(yīng)用系統(tǒng)中最耗時(shí)、最昂貴且最不確定的部分。因此,現(xiàn)代快速應(yīng)用開(kāi)發(fā)平臺(tái)整合了堅(jiān)實(shí)的基礎(chǔ)體系框架、提供了實(shí)現(xiàn)典型功能的完備組件,當(dāng)然,還有可以促進(jìn)快速開(kāi)發(fā)的工具。所有這些都是為了在項(xiàng)目的原型開(kāi)發(fā)階段和后續(xù)構(gòu)建過(guò)程中更快地交付成果。
Gartner 和 Forrester 這樣的咨詢(xún)公司一直在引入新的術(shù)語(yǔ)來(lái)區(qū)分這些平臺(tái):低/零代碼應(yīng)用平臺(tái)(LCAP)、高效率應(yīng)用平臺(tái)即服務(wù)(HPAPaaS)、多體驗(yàn)開(kāi)發(fā)平臺(tái)(MXDP)。但其實(shí),這些可以按其目標(biāo)受眾進(jìn)行分類(lèi)。
- 低代碼/零代碼平臺(tái)
例如:Mendix、Outsystems。
這些平臺(tái)的核心理念是使沒(méi)有開(kāi)發(fā)技能的業(yè)務(wù)用戶(hù)(指高級(jí)用戶(hù)或業(yè)余開(kāi)發(fā)人員)能夠非??焖俚亟桓犊捎玫膽?yīng)用程序。當(dāng)然,追求這種簡(jiǎn)單性的同時(shí)便意味著失去了靈活性,并且還有各種限制。我們?cè)?a class="pgc-link" data-content="mp" data-source="innerLink" href="http://detail/?aggr_type=2&groupid=7206255080440545804&item_id=7206255080440545804" rel="noopener noreferrer noopener noreferrer" target="_blank">低代碼 – 危險(xiǎn)的賭注文章中介紹了這些限制和相關(guān)的風(fēng)險(xiǎn)。這種類(lèi)型平臺(tái)的產(chǎn)出要么是原型,要么是非?;A(chǔ)的系統(tǒng)。
▲ 低代碼工作流
- 為專(zhuān)業(yè)開(kāi)發(fā)人員服務(wù)的平臺(tái)
例如:Embarcadero RAD Studio、Jmix、Ruby on Rails。
這些平臺(tái)主要通過(guò)提供更高級(jí)別的 API 和代碼生成來(lái)提升軟件開(kāi)發(fā)的速度和樂(lè)趣,開(kāi)發(fā)人員無(wú)需編寫(xiě)重復(fù)的樣板代碼和通用基礎(chǔ)功能。
Embarcadero RAD Studio(即以前的 Borland Delphi)是該領(lǐng)域的先驅(qū)之一,以可視化的 UI 設(shè)計(jì)器而聞名。誕生在網(wǎng)絡(luò)時(shí)代之前,目前仍然能用于桌面和移動(dòng)應(yīng)用開(kāi)發(fā)。
其他快速開(kāi)發(fā)平臺(tái)則更加關(guān)注 Web 應(yīng)用的開(kāi)發(fā),因?yàn)楝F(xiàn)在用戶(hù)主要通過(guò) Web 進(jìn)行交互。例如,在 Jmix 平臺(tái),我們嘗試提供便利、快速的數(shù)據(jù)模型和界面的可視化設(shè)計(jì),并結(jié)合了現(xiàn)代開(kāi)源技術(shù)的強(qiáng)大功能。這種方式不僅可以提高原型制作速度,還可以將原型進(jìn)行繼續(xù)開(kāi)發(fā),成為可靠且可擴(kuò)展的全功能企業(yè)應(yīng)用系統(tǒng)。
▲ 在 Jmix 中設(shè)計(jì)應(yīng)用程序界面
還不了解 Jmix? Jmix 快速開(kāi)發(fā)框架適合我嗎?
如果您有興趣深入研究 RAD 平臺(tái),我們還有一篇關(guān)于 RAD 發(fā)展的企業(yè)級(jí)快速開(kāi)發(fā)平臺(tái)的演進(jìn)供您閱讀。
結(jié)語(yǔ)
快速應(yīng)用程序開(kāi)發(fā)是遵循敏捷哲學(xué)的開(kāi)發(fā)方法之一。RAD 的關(guān)鍵原則是最終用戶(hù)的緊密參與以及基于用戶(hù)反饋的快速迭代原型設(shè)計(jì)。一旦用戶(hù)對(duì)原型滿(mǎn)意了,重點(diǎn)便轉(zhuǎn)移到了交付最終成型的產(chǎn)品上。
在項(xiàng)目中快速制作原型和成功實(shí)施 RAD 方法的最重要因素就是選擇正確的工具。針對(duì)不同類(lèi)型的應(yīng)用系統(tǒng)、項(xiàng)目階段和團(tuán)隊(duì)技能,可選的工具和平臺(tái)也相當(dāng)多。
RAD 是一個(gè)古老的概念,但如今隨著數(shù)字化轉(zhuǎn)型的趨勢(shì)以及快速推出產(chǎn)品的需求推動(dòng),它正在經(jīng)歷著復(fù)興。對(duì)于適合的項(xiàng)目類(lèi)型和團(tuán)隊(duì)配置,RAD 方法有助于在降低風(fēng)險(xiǎn)和縮短交付時(shí)間的同時(shí)提高用戶(hù)滿(mǎn)意度。