摘要:馬爾代夫之行重頭戲這一年的工作情況這一年,個人感覺還是做了不少事情,主要集中在我們公司的前端領(lǐng)域,同時也給整個技術(shù)團隊不少的建議,引入了不少新的東西和方式,總結(jié)起來比較重要的在下面五個方面。
如果想看技術(shù)相關(guān)的,下拉到后面的重頭戲就是了。
一個活動頁面在15年末的時候,加入到羅輯思維,剛過來就接手了一個微信朋友圈要傳播的活動頁面,效果頁面大概和當(dāng)時錘子手機的活動頁面漂亮的不像實力派類似,不過不同的是,采用了Vuejs來寫,單頁面,也踩了不少的坑。填坑日記在此html5 上傳本地圖片處理各種問題。
臨時上傳了一份代碼在github上,地址如下:http://leslieyq.github.io/204...
和朋友搭伙創(chuàng)建了一個網(wǎng)站15年末到16年初,在我大學(xué)好基友@葉孤城__的提議下,我們做了一個專門搞Code Review的網(wǎng)站,網(wǎng)站地址。做這個的原因就是覺得Code Review很重要,但是重視的公司很少,大家覺得很多時候,沒有bug就行,不會去管這些東西。而我們覺得Code Review 是一種最快捷有效的方式讓你清楚地知道“好的代碼是怎樣寫出的”。所以幾個趣味相投的人搞出來這個網(wǎng)站,雖然現(xiàn)在已經(jīng)沒有維護和運營了,但當(dāng)時還是非常有激情和想法的。
從這個網(wǎng)站,脫胎出的一個變種想法,已經(jīng)被我們當(dāng)時合伙人之一的李智維做了一個新的網(wǎng)站,叫做趣直播技術(shù)直播網(wǎng)站,很有意思,大家感興趣可以去看看。我還在里面直播了一期前端的技術(shù),雖然聽的人很多都是IOS開發(fā),直播地址:1024號的碰巧。
再次馬爾代夫之行過春節(jié)的時候,沒有回老家,和老婆以及好基友去了一趟馬爾代夫,這是我第二次去馬爾代夫了,上次是15年8月度蜜月的時候,說說我為什么又去一次,很簡單就是覺得值的再去一次。
我不太喜歡,那種去到處趕景點的旅游,真的是到此一游的感覺,反而比較喜歡慢節(jié)奏的旅行,可能是平時節(jié)奏就比較快吧,出去玩就想單純的放松下,不去什么太多的景點,體驗各種人文風(fēng)情之類的,找個景色好,環(huán)境好,能讓人感覺到舒適的地方,躺下,每天吃喝玩休息對于我而言就是最好的放松了。
這次旅游,好基友有個文章專門記錄了下,也是他的第一次出國之旅。馬爾代夫之行
重頭戲---這一年的工作情況這一年,個人感覺還是做了不少事情,主要集中在我們公司的前端領(lǐng)域,同時也給整個技術(shù)團隊不少的建議,引入了不少新的東西和方式,總結(jié)起來比較重要的在下面五個方面。
1.推動了整個WEB前端技術(shù)架構(gòu)體系的演進首先說明下我們目前基本上所有項目(幾個特殊的除外)都是用Nodejs作為一個比較輕薄的中間層來啟動。這是一個基本情況,這樣有利于理解我接下來說的東西。
各個不同的層級都做了什么,做決定時怎么想的:
訪問層,分為2個部分(靜態(tài)和服務(wù)端),靜態(tài)資源的CDN,因為我們是部署在阿里云上面的,所以直接使用的是阿里云的CDN服務(wù),不得不吐槽下,阿里云的CDN服務(wù)不是很穩(wěn)定,不如他們自家淘寶用的CDN給力啊。服務(wù)端用Nginx在外層提供HTTPS服務(wù),反向代理我們自己啟動的Nodejs服務(wù),同時使用了阿里提供的多機器的負(fù)載均衡服務(wù),來保證了項目的穩(wěn)定性。
代碼層,瀏覽器端代碼,基于Vuejs編寫,同時使用我們自己開發(fā)的Radon-UI組件庫,拼接頁面元素,開發(fā)效率急速提升。服務(wù)端Express核心框架,結(jié)合Thenjs解決異步問題,Request代理API服務(wù),Render頁面給瀏覽器。根據(jù)頁面的業(yè)務(wù)要求,會有兩種情況,一種Render頭尾部,然后JS異步獲取數(shù)據(jù),渲染頁面,第二種Render整個首屏頁面,部分彈出層或者DOM使用js來管理。幾個特殊的系統(tǒng)和頁面,Nodejs擔(dān)任的任務(wù)就變多了,比如我們給運營開發(fā)的活動頁面生成系統(tǒng),使用mongoDB來存儲運營填寫的文案和上傳到阿里云OSS圖片地址之類。還有我們得到APP訂閱文章的紅包分享項目,里面為了存儲用戶信息,使用Redis來存儲Session信息。
工具層,這里我們有一個Yeoman的generator,可以直接生成新項目的各種配置和基礎(chǔ)代碼文件,使用webpack來開發(fā)和打包構(gòu)建,添加Md5戳到我們的靜態(tài)資源上,增量部署到CDN上。同時用到Gulp的原因是有很多老項目還在使用,沒有完全的切換過來,但現(xiàn)在也正在一步一步切換。使用Sass和Babel,提供了css的模塊化和提高了css的可維護性。Babel讓我們有了開發(fā)環(huán)境下直接使用ES6的可行性。NPM作為項目的包管理,同時我們搭建私有的NPM源,來保證更新包時候的速度和穩(wěn)定性(還記得?Azer Ko?ulu 刪除了自己的所有 npm 庫的事件么)。
部署層,這里主要是運維的場地,對于我們前端而言,主要是靜態(tài)資源的部署和Nodejs代碼的上線。我們使用自己內(nèi)容搭建的部署系統(tǒng)搞定這個事情,添加上權(quán)限管理和回滾機制,靜態(tài)資源使用增量部署,保存無縫切換,先行部署靜態(tài)。服務(wù)端采用替換部署機制,就是說,在負(fù)載均衡上,踢掉一臺,部署一臺,再上線到負(fù)載上,重復(fù)到所有機器完成為止。保證服務(wù)穩(wěn)定,不間斷。
監(jiān)控層,這里就有很多包含很多東西了,有第三方的,我們自己開發(fā)的,還是開源的。關(guān)于服務(wù)端報警我們采用了Sentry來監(jiān)控錯誤,一旦發(fā)生錯誤,我們就用Sentry發(fā)送郵件給相關(guān)人??梢粤⒖讨厘e誤的地方和原因。同時,在性能方面,我們使用第三方的One APM來監(jiān)控性能指標(biāo),這樣就能知道哪些頁面加載比較慢,需要優(yōu)化,優(yōu)化的點在哪里。對于Nodejs有一個問題,就是進程監(jiān)聽方面,這里我們選用了PM2來做進程監(jiān)聽,保存線上的進程一單出錯奔潰,就能自動拉起服務(wù),不會因此僵死在那里。加上使用Log4js來輸出日志到知道文件,接著使用阿里云的日志服務(wù),監(jiān)聽日志文件,輸出到日志服務(wù)系統(tǒng),就可以直接在外網(wǎng)環(huán)境中看到日志的詳情以及上下文情況,非常有用。最后我們自己搭建了一個Foundation前端系統(tǒng),專門留給前端自己使用的,主要目的是提供一些自身部門需要的服務(wù),包括收集操作日志和文件上傳功能等,后續(xù)可能還會提供更多功能。
以上的架構(gòu)是根據(jù)團隊的人員配比,技術(shù)水平,以及業(yè)務(wù)需求來搭建的,并不一定要追求所謂的高大上,所謂的完美,很多時候要綜合考慮。
這個架構(gòu)和美團酒旅的前端技術(shù)很像,但是有略有不同,比他們少了不少東西。大家看的時候可以互相參考,結(jié)合自己當(dāng)前的業(yè)務(wù)形態(tài)以及團隊技術(shù)水平來搭建公司的技術(shù)架構(gòu)體系。
2.主導(dǎo)了我們公司自己的組件庫在一個合適的時機,我主導(dǎo)開發(fā)了一個基于Vuejs的公司用到的組件庫,并且最后開源出來了。起名為 Radon-ui
開發(fā)這個庫的主旨是: 幫助你快速開發(fā)產(chǎn)品的Vue組件庫,簡潔好用,效率高,讓你擺脫各種定制化的煩惱。
這個庫具體的一些前因后果可以看我這篇文章,簡單一點就是在滿足自己公司的需求情況下,開發(fā)了一個開源的組件庫回饋社區(qū),而且當(dāng)時vue的組件庫確實空白,當(dāng)然后面就出現(xiàn)了好多類似的各種組件庫。
3.開發(fā)了定制化的文章編輯器我司在16年開始,有2條不太相同的業(yè)務(wù)線,一條是原來的微信公眾號,羅輯思維,另外一個是得到App,主打知識分享,提供省時間的高效知識服務(wù)。
使用過我們得到App的人,應(yīng)該是知道的,我們有一個訂閱專欄,里面有訂閱文章可以觀看,這個文章的技術(shù)棧都是Web前端的,包括編輯器,展示,以及里面的各種操作。最初使用的是百度編輯器,后面遇到了好多問題,主要是定制化,樣式,字體問題。所以后面為了提供更好的閱讀體驗,我們重新開發(fā)了一個屬于我們自己的定制化編輯器,融合了特殊字體切割技術(shù),整體大幅提升了閱讀時的體驗和效果。為此我寫了兩篇文章:
富文本編輯器小結(jié)
性能優(yōu)化之旅
4.鼓動前端所有人參加了D2技術(shù)分享在一個明媚的午后,我們前端組開著周會,討論著本周的事情和技術(shù)問題,我收到了D2技術(shù)論壇開始報名的消息,于是趁熱打鐵在會上就鼓動了大家去參加這個分享,風(fēng)風(fēng)火火一行人7個,直接就報名參加了,然后就是訂機票和酒店。
具體討論大家可以去知乎上看:參加第11屆D2前端技術(shù)論壇,你有什么收獲
對于這一屆的D2,說實話我是失望的,感覺比不上上一屆,各種大廠的廣告橫飛,都是比較淺顯的東西,深入的很少。但是還是有引起我對于前端的一些思考,比如說是否應(yīng)該更多的和Native的人一起考慮App的各種技術(shù)融合方案,跨界的Weex技術(shù),以及Uc瀏覽器里面UC頭條的性能優(yōu)化。
例如美團的人的思考:統(tǒng)一的前端
5.保持了一定頻率和質(zhì)量的技術(shù)文章算算自己的15年,產(chǎn)出了12篇文章,基本上算是1個月一篇,其中有一個系列叫《如何打造一個令人愉悅的前端開發(fā)環(huán)境》,這個系列還蠻多人看的,也有不少公眾號轉(zhuǎn)載了的,在segmentfault還因此獲得了第三季度的Top Writer,算是意外收獲吧(嘚瑟臉:)!
這養(yǎng)成了我一個習(xí)慣,覺得有意思有意義的技術(shù)點,就記錄下來和大家分享,也算是一種梳理,這種梳理對于我而言,很有作用,每隔一段時間就會思考業(yè)內(nèi)前端的各種發(fā)展,以及我自身的優(yōu)缺點,我需要提高的地方。這種梳理,誕生了16年最后一篇技術(shù)文章---割裂的前端工程師,這篇文章也被百度FEX周刊收錄進去,還有不少前端相關(guān)的公眾號收錄(前端早讀課,前端之巔--infoq的,野狗等),非常欣慰,對我是很大的鼓勵和認(rèn)同。
連續(xù)的產(chǎn)出一定質(zhì)量的文章,也帶來了另外的一個意外收獲,就是有出版社約我出書,2個不同的人,雖然還沒有寫,主要是不知道寫什么,又害怕寫的不好,耽誤了有志青年。
同時還在給慕課網(wǎng)錄制一些教學(xué)視頻,希望能早日上線(說的不好,不要打我)?。?!
結(jié)尾互聯(lián)網(wǎng)這條路,沒有終點,只會不停地奔跑下去。
不忘初心,不懼未來!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/86670.html
摘要:然而這次的文章,就像賀師俊所說的這篇文章是從程序員這個老年度總結(jié)前端掘金年對我來說,是重要的一年。博客導(dǎo)讀總結(jié)個人感悟掘金此文著筆之時,已經(jīng)在眼前了。今天,我就來整理一篇,我個人認(rèn)為的年對開發(fā)有年終總結(jié)掘金又到 2016 Top 10 Android Library - 掘金 過去的 2016 年,開源社區(qū)異?;钴S,很多個人與公司爭相開源自己的項目,讓人眼花繚亂,然而有些項目只是曇花一...
摘要:因為涉及業(yè)務(wù)敏感話題,本文只記錄我們學(xué)習(xí)的歷程。我由衷的感謝團隊的小伙伴們,感謝你們的堅韌不拔,感謝你們的持續(xù)成長。這個變化只是在每天的堅持和刻意練習(xí)中發(fā)生的,是那么的神奇。 因為涉及業(yè)務(wù)敏感話題,本文只記錄我們學(xué)習(xí)的歷程。 關(guān)于堅持 ??從2016年起,我們團隊堅持每天早晨8:50-10:30的100分鐘早晨討論,到現(xiàn)在已經(jīng)兩年了,期間沒有中斷過。我由衷的感謝團隊的小伙伴們,感謝你們...
摘要:因為涉及業(yè)務(wù)敏感話題,本文只記錄我們學(xué)習(xí)的歷程。我由衷的感謝團隊的小伙伴們,感謝你們的堅韌不拔,感謝你們的持續(xù)成長。這個變化只是在每天的堅持和刻意練習(xí)中發(fā)生的,是那么的神奇。 因為涉及業(yè)務(wù)敏感話題,本文只記錄我們學(xué)習(xí)的歷程。 關(guān)于堅持 ??從2016年起,我們團隊堅持每天早晨8:50-10:30的100分鐘早晨討論,到現(xiàn)在已經(jīng)兩年了,期間沒有中斷過。我由衷的感謝團隊的小伙伴們,感謝你們...
閱讀 2192·2021-11-19 09:55
閱讀 2656·2021-11-11 16:55
閱讀 3186·2021-09-28 09:36
閱讀 1953·2021-09-22 16:05
閱讀 3288·2019-08-30 15:53
閱讀 1814·2019-08-30 15:44
閱讀 2905·2019-08-29 13:10
閱讀 1350·2019-08-29 12:30