“前端”工匠系列(二):合格的工匠,怎么做好價值落地
此文為系列文章第一篇,為淺嘗輒止的引入,目的是為了讓前端從業(yè)人員及非從業(yè)但是對此領域感興趣的人對于”前端“是干什么的這個話題有個無門檻的了解。
“前端職能是什么”
說起"前端",維基百科對這個技術角色的定位是“前端(英語:front-end)和后端(英語:back-end)是描述進程開始和結束的通用詞匯。 前端作用于采集輸入信息,后端進行處理。 計算機程序的界面樣式,視覺呈現屬于前端?!睂τ诋斚路沼诨ヂ?lián)網各企業(yè)的前端研發(fā)人員來說,這個崗位定義是很清晰的。前端是個對于后端的相對概念,它的崗位角色更應該關注“采集和呈現”兩個部分。
從以上的概念來看,前端研發(fā)的正常職責是通過編碼工作對數據及業(yè)務邏輯進行展示,用戶通過操作界面(或其他交付方式)與系統(tǒng)進行交互,最后用戶的交互信息可以按照功能邏輯的預期傳輸到后端服務遞交給業(yè)務后端及更下游的算法層處理。
?
“編碼工作包括什么呢?”
前端研發(fā)人員工作對接的上游干系人包括產品和UI設計,必要輸入有產品文檔和UI設計稿件,下游干系人為后端研發(fā)人員,必要的輸出為一整套界面交互及邏輯處理實現代碼。
產品要向研發(fā)團隊輸出PRD(產品需求文檔Prodcut Requirement Document的簡稱)來對此次產品或者迭代的具體的功能細節(jié)進行詳細的描述,通過需求評審會議的方式與研發(fā)人員和設計人員進行“語言的互通轉換及翻譯”工作,得以把所有的產品邏輯向不同專業(yè)人員表達清晰,這是一切需求交付最重要的環(huán)節(jié)。對于新增的或者復雜的需求,需要有交互設計人員與產品人員共同輸出交互設計稿件,從另外一個維度對產品需求邏輯進行闡述,對于前端研發(fā)人員對于需求理解的清晰程度來看,交互設計稿件的嚴謹和質量十分重要。
UI設計人員需要根據產品需求文檔和交互設計稿件對界面的UI風格、色系及動效等素材進行設計畫制作,向研發(fā)人員輸出UI設計稿件,此項工作需要前端研發(fā)、產品和設計人員進行多輪溝通以便敲定所有元素細節(jié)。UI設計稿件的設計質量和對產品邏輯的描述精細度,直接對前端研發(fā)人員的編碼設計方式和效率產生影響,前端研發(fā)人員必須對UI設計稿件有足夠的重視,避免在實現過程中反復與產品和設計人員對設計稿件的細節(jié)進行確認甚至重新設計。如果這種情況出現,勢必對項目的排期產生影響。最后,前端研發(fā)的界面輸出要通過UI設計人員的驗收測試才算完成界面編碼工作。
與后端研發(fā)人員的對接是研發(fā)工作中的重中之重,最終,一整套前后端研發(fā)人員公認的經過冒煙用例自測的代碼包才是此階段的合格產出物。接口規(guī)范、約定習慣以及默契度較高的對接伙伴,都是業(yè)界不斷在研發(fā)調試、聯(lián)合調試以及提測冒煙過程中提效降本的思路?!耙磺卸际侨说氖隆薄凹s定大于習慣”這些對軟實力、流程的嚴謹程度都提出了要求。
研發(fā)流程中最后的步驟是UAT驗收后上線。上線一定要采用“流水線自動化”的方式才行,也就是大家常說的“CI/CD”。只有這樣做,才能保證主干版本代碼與線上代碼版本完全保證一致,不會因為人為把自己本地代碼編譯打包后發(fā)布到線上,導致主干分支成為擺設;所有上線相關的合并、編譯、打包、發(fā)布等核心流程都是流水線自動跑事先部署在流水線各個節(jié)點的腳本,才能避免人為操作“失誤”導致的線上問題。
“上線了?”
上線是個很值得探討的話題,因為對于研發(fā)來說,只有上了線并且發(fā)揮了預期或者超預期的業(yè)務價值的代碼,才算是對企業(yè)、對社會有一點點貢獻,個人的價值才能在工作中得以體現。上線完成就是研發(fā)工作的結束嗎?對于很多研發(fā)團隊來說,這就是最后一步了。但是,研發(fā)流程僅僅止步于此,是不符合“合格”這個標準的。一套代碼,只有在上線后,才開始受到真正用戶的親測使用,研發(fā)人員的產出物才算是“生命開始”。產品功能在用戶的使用中“表現是否符合預期”、“是否有邊界異?!?、“是否存在打不開頁面的情況”、“是否存在顯示異常的情況”,諸如此類的問題,都應該是產研需要關注的話題。
因此,研發(fā)人員需要預先在代碼包中預留與線上真實用戶“交流”的抓手,通過分析用戶在“可用性和性能”做出可以提升用戶體驗的改進措施,例如,“特殊邏輯自定義埋點上報”、“邊界兜底監(jiān)控”、“系統(tǒng)運行時監(jiān)控”等,只有做到了這些,才能說對一個用戶功能的真正上線,后續(xù)也才有精細化運營的可能。可是,對于很多研發(fā)人來說,“上線即需求的終點”、“線上問題由業(yè)務反饋”、“有客訴嗎?”都是研發(fā)普遍存在的心理。
那如何通過“預先”的方式建立與用戶之前的溝通通道呢?因為此文為前端領域文章,所以我們此次只說前端部分。
“與用戶交流”
有效的交流是需要以有效的信息為載體的。對于技術實現來說,就是對核心代碼塊進行合理的代碼埋點。當特殊用戶行為發(fā)生時,當代碼處理邏輯走向了一個非正常的處理單元時,當發(fā)生了代碼處理邏輯沒有覆蓋到的情形時,埋點上報代碼就會觸發(fā)執(zhí)行,向中心化的埋點服務發(fā)送消息。技術人員通過對此次用戶行為觸發(fā)的埋點信息的分析,從而得到用戶在瀏覽或操作頁面過程中的“正?;虍惓!鼻闆r的“現場復現”,當然,這種復現可以是數據信息,也可以是截圖或視頻回溯,具體要用什么方式來復現用戶行為,要以“有效”為目標,綜合考慮“用戶流量成本、研發(fā)成本、性能影響以及存儲成本”等因素來最終選型。
“實時 OR T+1”
對于業(yè)務前端用戶行為及觸發(fā)邏輯的監(jiān)控,有實時監(jiān)控和異步監(jiān)控兩種。
在實時關注用戶行為、實時分析等場景里,需要使用實時監(jiān)控,這個“實時”,一般到秒級就夠用了,一些業(yè)務使用分鐘級也是可以的,具體看業(yè)務的需要。對于實時監(jiān)控,上報行為是從每一臺用戶的設備上觸發(fā)并上報的,應用于大體量業(yè)務來說,這個數據量的采集、上報、收集、存儲、分析和報表的生成,都是相當耗費資源的。為了降本提效,埋點服務首先會對用戶數據按照特殊的規(guī)則(比如正態(tài)分布)進行一層比例的抽樣,降低分析及報表生成過程中對資源和人力的消耗。
在用戶端日志查詢、特殊邊界場景復現、日志排查定位故障等場景,“實時”就不是必要的,這種場景下一般采用T+1查詢,但是又引入了大量級日志的存儲周期的話題,一般企業(yè)應用級的用戶日志保存14天就完全夠用了,因為對于C端日志來說,更多的是對現場故障的復現、處理及跟進,如果算法策略對用戶日志有需要,只需要在一定時間內采用處理任務對用戶日志進行一次處理,把輸出的標簽、行為特征等關鍵數據存儲就可以,基礎的用戶日志還是應該被存檔或清除釋放資源供給更有價值的最新日志來使用。
綜上所述,實時監(jiān)控和非實時監(jiān)控分別應對兩種場景:實時對應“業(yè)務可用性、線上運行時異?!钡仁褂迷V求,非實時對應“性能指標、用戶日志查詢、用戶行為復現”等使用訴求。
“后續(xù)”
之后會繼續(xù)講述一些有關"用戶體驗、效率提升、頁面搭建"相關的話題。
審核編輯 黃宇
-
監(jiān)控
+關注
關注
6文章
2223瀏覽量
55300 -
前端
+關注
關注
1文章
199瀏覽量
17801
發(fā)布評論請先 登錄
相關推薦
評論