前後端分離,我怎麼就選擇了 Spring Boot + Vue 技術棧?
前兩天又有小夥伴私信鬆哥,問題還是職業規劃,Java 技術棧路線這種,實際上對於這一類問題我經常不太敢回答,每個人的情況都不太一樣,而小夥伴也很少詳細介紹自己的情況,大都是一兩句話就把問題丟擲來了,啥情況都不瞭解,就要指出一個方向,這實在是太難了。
因此今天我想從我學習 Spring Boot + Vue 這套技術棧的角度,來和大家聊一聊沒有人指導,我是如何一步一步建立起自己的技術體系的。
線上大家看我經常寫文章,線下我其實比較宅,跟人交流比較少,我也很少問別人職業規劃或者技術規劃這些問題,因為這種學什麼的問題,我喜歡自己把握,我不太喜歡被別人牽著走。
Rome was not built in a day
,剛開始接觸 Spring Boot + Vue 時,我甚至都沒有一個明確的想法,只是覺得該學點什麼,不能讓時間浪費,沒有告訴我 Spring Boot 要火了,也沒有人告訴我 Vue 要超過 React 了,都是我自己一直在摸索摸索,一步一步,直到構建起這套技術大廈。
Spring Boot
先說說 Spring Boot 吧,三年前差不多也是這個時候,是我第一次接觸 Spring Boot ,那個時候我的正式身份還是一名 Android 工程師,那段時間在研究 Android7 的原始碼,還寫了一些部落格:
但是那個時候 Android 的行情在慢慢下滑,而我剛畢業 1 年多,未來還有更加豐富的技術人生,我不願意這麼早就把技術棧定死,而且還定在一個行情日漸下滑的技術棧上。所以我打算學一點新的東西。
Python、Go、前端 和 Java 都是備選的方向,但是最終還是選擇繼續做 Java,有三個原因:
- 做 Java 當時可以在公司內部轉崗,做 Python 或者 Go 的話,可能就得換工作了,技術棧切換,一切從頭開始,當時心裡還是沒底,於是就選擇繼續做 Java
- 剛好大學的時候也有 JavaEE 的底子,重新撿起來 JavaEE 相關的技術點倒也不是啥難事
- 第三點也是最重要的一點,我一直希望能夠獨立接點私活,這樣有一天賺錢能夠不受工作地點的限制,基於這樣的初衷,我一直希望走全棧的路線,用 Python 和 Go 雖然也可以做企業級應用,但是在目前的技術環境下,這並不算是主流方案,主流方案依然是 Java ,雖然它被被多人吐槽
基於以上三點,我決定還是走 Java 的方向吧。
2016 年那會,CSDN 幾乎每個月送我一本技術圖書,10 月份的圖書我就和夢鴿美女要了一本 Spring Boot 相關的書,書到了之後,一直在忙各種事情沒時間看,到了當年 12 月份的時候,公司安排我去深圳出差,出差的話,每天下班後時間就比較充裕了,於是我就帶上了書,每天下班回到酒店,就開始搞 Spring Boot。
一開始我就發現這玩意相比我大學時候搞得 XML 配置的 SSM 太好用了,還是 SSM 那套東西,但是有了自動化配置,不用再去寫讓人頭大的 XML 配置了,可以基於 Spring Boot 快速搞一個 SSM 應用出來。不過剛開始學的時候我還不知道 Spring Boot 在 Java 領域如此火爆,當我寫了幾篇部落格之後,我發現每篇部落格的閱讀量都暴漲,遠遠高於其他部落格的閱讀,我隱隱約約感覺到這次稀裡糊塗的技術棧切換,算是沒走錯路。
不過老實說,Spring Boot 技術棧其實不算難,都是 SSM 那一套東西,只是多了自動化配置(當然,Spring Boot 也有不少自己的東西,不過整體上基於 SSM 這點應該沒啥爭議),我剛開始搞 Spring Boot 的時候,有時候會有一些東西看的雲裡霧裡,後來發現問題出在 Spring + SpringMVC 上,好幾年不寫 JavaEE,這些東西有一點點生疏了,後來又花了一些時間把 SSM 這些東西系統過了一遍,然後再去看 Spring Boot 就順暢多了。
所以有一些小夥伴問鬆哥能不能跳過 SSM 直接學習 Spring Boot,這個我不建議,大家在 Spring Boot 中見到的很多神奇的自動化配置大部分都是基於 Spring 現有功能實現的,要是不懂實現原理,你會發現 Spring Boot 用得時候雖然好用,但是出了問題,你就束手無策了。
就這樣,跳入了 Spring Boot 的坑裡了。Spring Boot 學完沒多久,工作上,馬上要從 Android 切換到 JavaEE 了,亟需一個專案練練手,當時我的上司給我介紹了一個西藏大學的專案,我使用 Spring Boot+EasyUI 的技術棧花了不到一個禮拜做完了,從此就算是叩開了 JavaEE 的大門,那會是 2017 年。
當時前端選擇 EasyUI 也是沒辦法,甲方催得緊,而我來不及搞其他的前端框架,當時只有 EasyUI 熟悉一些,不用花時間學,直接就能用,於是就選擇了 EasyUI,但是 EasyUI 太醜了,所以在做完西藏大學的專案後,我就一直思量著再整一個專業的前端框架,這樣以後再有私活,我就可以獨立做出來一個好看的後端管理系統了。
就這樣,在綜合對比了 Vue、React 以及 Angular 之後,決定跳入 Vue 的坑。
Vue
前端其實還算接觸的比較早,最早的 jQuery Mobile,PhoneGap 上大學的時候就玩過,我的第一本 NodeJS 的書是在 2013 年買的,那個時候 NodeJS 還算是一個比較新的事物。當我還是一名 Android 工程師的時候,我就玩過 React 和 ReactNative,RN 是當時比較流行的一個跨平臺解決方案。但是在我比較這三個技術棧的時候,我發現 Vue 更加好用,生態也更加豐富,而且大有超過 React 的架勢(當時 Vue 在 GitHub 上的 star 數還沒超過 React),於是我就選擇了 Vue。其實當時我心裡想,大不了學完 Vue 再學 React,反正我才剛畢業兩年多,沒必要這麼早就鎖定技術棧停止學習。
Vue 的學習確實不費啥事,花了兩三天時間刷了一遍官網,然後就開始做專案,但是要去深入學習,又是一個漫長的過程了。
Vue 有很多漂亮的 UI 庫,像 ElementUI 等都算是做的比較好的,這些東西只要會用其中一個,其他的就可以手到擒來。
到 2018 年初,Spring Boot+Vue 技術棧基本上已經熟悉了,兩個開源專案 V 部落(V 部落)和微人事(視訊揭祕微人事專案實現過程)也受到小夥伴們的歡迎,常規的企業級應用可以一個人獨立完成了,5 月份的時候,經朋友介紹,接了哈爾濱工程大學一位老師的專案,毫無疑問我就使用了最擅長的 Spring Boot+Vue 技術棧來做了,前後端都是自己做,沒人扯皮,美滋滋。
再後來,就是寫書(我的第一本書,被選作大學教材了!),業餘繼續搞點專案用 Spring Boot + Vue 來做,這些以前都和大家聊過我就不再多說了,業餘接點專案來做這塊倒是有一些經驗,以後和小夥伴們細聊。
就這樣,沒有任何人的指引,我慢慢構建了 Spring Boot + Vue 這套技術體系,這個過程中,最大的學習經驗就是要寫部落格,做筆記,寫部落格不僅僅是記錄,也是總結提煉,在寫的過程中,融入自己的思考,加深對技術的理解。 掌握了這套技術棧之後,我覺得我離全棧又更近了一步,離賺錢不受工作地點的限制這個目標也更近一步了。
結語
有前輩大佬的指引,你可能走得快,自己摸索,走的踏實。其實從我第一天自學 Java 開始,基本上都是一直在摸索。大學時候一個 BUG 折騰兩三天才解決,但是一旦自己想明白解決了,以後類似的錯誤不會再犯,這是我的感受。
好了,一點點學習經驗,和小夥伴們分享,要是覺得有啟發,歡迎轉發哦。
掃碼關注鬆哥,公眾號後臺回覆 2TB,獲取鬆哥獨家 超2TB 學習資源
相關文章
- 使用Vue,Spring Boot,Flask,Django 完成Vue前後端分離開發(二)VueSpring BootFlaskDjango後端
- 前後端分離技術路線圖後端
- Vue+Spring Boot 前後端分離的商城專案開源啦!VueSpring Boot後端
- 談談前後端分離及認證選擇後端
- Spring Boot + Vue 前後端分離,兩種檔案上傳方式總結Spring BootVue後端
- 用jQuery怎麼做到前後端分離jQuery後端
- vue前後端分離修改webpackVue後端Web
- 全棧的自我修養: 001環境搭建 (使用Vue,Spring Boot,Flask,Django 完成Vue前後端分離開發)全棧VueSpring BootFlaskDjango後端
- 記一次Spring boot 和Vue前後端分離的入門培訓Spring BootVue後端
- Spring Boot前後端分離專案Session問題解決Spring Boot後端Session
- Spring Boot + Vue 前後端分離開發,前端網路請求封裝與配置Spring BootVue後端前端封裝
- 什麼是前後端分離?後端
- 喜大普奔,兩個開源的 Spring Boot + Vue 前後端分離專案可以線上體驗了Spring BootVue後端
- 為什麼前後端分離了,你比從前更痛苦?後端
- 我們為什麼要嘗試前後端分離後端
- node-vue前後端分離記錄Vue後端
- java版Spring Cloud、Vue前後端分離社交電商微服務JavaSpringCloudVue後端微服務
- Django+Vue.js搭建前後端分離專案 web前後端分離專案實踐DjangoVue.js後端Web
- 都前後端分離了,我們就別做頁面跳轉了!統統 JSON 互動後端JSON
- 通用的前後端分離專案技術與框架方案後端框架
- spring shiro+cas 前後端分離Spring後端
- spring boot + vue + element-ui全棧開發入門——前後端整合開發Spring BootVueUI全棧後端
- ruoyi vue 前後端分離版本 打包分離jar包至libVue後端JAR
- Laravel vs. Spring Boot:後端開發選擇LaravelSpring Boot後端
- python django框架+vue.js前後端分離PythonDjango框架Vue.js後端
- 再談前後端分離後端
- 前後端分離那些事後端
- 淺談前後端分離後端
- 前後端分離——使用OSS後端
- laravel+vue前後端分離之伺服器端配置LaravelVue後端伺服器
- 實戰!Spring Boot Security+JWT前後端分離架構登入認證!Spring BootJWT後端架構
- 實戰!spring Boot security+JWT 前後端分離架構認證登入!Spring BootJWT後端架構
- 前後端分離後的前端時代後端前端
- 前後端分離後模組開發後端
- 「分享」基於vue-element+laravel8.x+casbin 我寫了一個前後端分離的rbac管理後臺VueLaravel後端
- 前後端分離 Vue + NodeJS(Koa) + MongoDB,從產品到開發,全棧實踐後端VueNodeJSMongoDB全棧
- spring boot + vue + element-ui全棧開發入門——spring boot後端開發Spring BootVueUI全棧後端
- SpringBoot,Vue前後端分離開發首秀Spring BootVue後端