Vue+Node.js+MongoDB 個(gè)人博客項(xiàng)目總結(jié)(一)

一直就有要做一個(gè)前后端完整的個(gè)人項(xiàng)目的想法鲫竞,但因?yàn)閷W(xué)校和面試的事一直沒(méi)開(kāi)始。兩個(gè)星期前開(kāi)始了行動(dòng),選定Vue + express + mongoDB 的技術(shù)棧。Vue框架的文檔還是非常友好易懂的袜茧,一個(gè)星期看官方文檔和寫(xiě)小demo,一個(gè)星期開(kāi)始正式開(kāi)發(fā)瓣窄。總算完成了主體功能的開(kāi)發(fā)∧啥Γ現(xiàn)在寫(xiě)個(gè)文章做個(gè)階段性總結(jié)俺夕。

Github地址:https://github.com/Howell5/Josephong.me

項(xiàng)目架構(gòu)圖

個(gè)人博客項(xiàng)目架構(gòu)圖.png

client

  • 技術(shù)框架和基本庫(kù):
  • 用了Vue-cli 構(gòu)建基本項(xiàng)目目錄,Vue-Router 做路由控制贱鄙,用 axios 庫(kù)做 ajax 操作劝贸。
  • 前臺(tái)展示頁(yè)(/psot 和 /postDetail)
    • 用 Marked.js 和 highlight.js 處理 Markdow 轉(zhuǎn)化為 HTML。從服務(wù)器拿到數(shù)據(jù)進(jìn)行渲染逗宁。
    • UI 借用了尤雨溪大佬博客的風(fēng)格映九,因?yàn)閷?shí)在沒(méi)想好自己的博客風(fēng)格,后期會(huì)改瞎颗。
  • 后臺(tái)管理頁(yè)(/admin 和 /admin/articleEdit)
    • 這里用到了嵌套路由件甥。編輯器用了第三方插件 simplemde渊季。
    • UI 用 element-ui 很快能搭建好颖榜,畢竟不是展示頁(yè),簡(jiǎn)潔好用就行。

Webpack作為靜態(tài)資源的打包和發(fā)布工具微猖。

server

服務(wù)端部分采用 express 作為開(kāi)發(fā)框架,提供api接口服務(wù)給前端ajax調(diào)用业踏,后端不做頁(yè)面模板的渲染和路由的導(dǎo)航工作盛撑,這部分都由前端的 vue 來(lái)處理,所以該博客其實(shí)是一個(gè)前后端分離曾我,以 RESTful api 來(lái)通信的單頁(yè)應(yīng)用粉怕。

因?yàn)橹饕壿嬏幚恚m然也沒(méi)有多少業(yè)務(wù)邏輯)都放在了前端,所以服務(wù)端寫(xiě)的很簡(jiǎn)單抒巢。利用 mongoose 與數(shù)據(jù)庫(kù) MongoDB 建立連接贫贝,并寫(xiě)好CURD(增刪改查)的接口給前端用就行了。

不得不說(shuō)這種開(kāi)發(fā)方式很爽虐秦,不像以前后端丟一個(gè)JSP頁(yè)面平酿,然后才能進(jìn)行前端工作。我個(gè)人認(rèn)為 業(yè)務(wù)進(jìn)行前后端分離悦陋,而個(gè)人開(kāi)發(fā)者進(jìn)行全棧發(fā)展蜈彼。

難點(diǎn)

跨域

因?yàn)樵趘ue-cli中本身就有一個(gè)小型服務(wù)器(本項(xiàng)目中:localhost:8525)供我們的vue項(xiàng)目跑起來(lái),但我們需要的數(shù)據(jù)是我們自己搭建的服務(wù)器(本項(xiàng)目中:localhost:9999)提供給我們的俺驶。因?yàn)闉g覽器的“同源政策”幸逆,我們不能直接進(jìn)行跨域訪問(wèn),解決方案也有很多暮现。CORS还绘,jsonp,...栖袋。詳情見(jiàn)文章 瀏覽器同源政策及其規(guī)避方法---阮一峰拍顷。而在我們的項(xiàng)目中,webpack-dev-server 給我們提供的proxy模塊塘幅,可以很快解決這個(gè)問(wèn)題昔案。配置如下:

** config/index.js **

  dev: {
    env: require('./dev.env'),
    port: 8525,
    autoOpenBrowser: true,
    assetsSubDirectory: 'static',
    assetsPublicPath: '/',
    proxyTable: {
      '/api': {
        target: 'http://localhost:9999
        changeOrigin: true
      }
    },

嵌套路由

一開(kāi)始在文章管理后臺(tái)中,我比較頭痛組件復(fù)用問(wèn)題电媳,在github看了相似項(xiàng)目的源碼踏揣,發(fā)現(xiàn)他們直接用復(fù)制代碼解決,顯然代碼冗余嚴(yán)重匾乓。在看Vue-Router的文檔中捞稿,一開(kāi)始并沒(méi)有注意嵌套路由的作用,后面多看幾遍就發(fā)現(xiàn)嵌套路由可以很完美解決這個(gè)問(wèn)題(果然官方文檔還是要反復(fù)看的)。我的路由配置:

{
      path: '/admin',
      name: 'admin',
      component: admin,
      children: [
        {
          path: '/',
          component: articleList
        },
        {
          path: 'articleList',
          component: articleList
        },
        {
          path: 'articleEdit',
          component: articleEdit
        },
        {
          path: 'articleEdit/?id=:id',
          name: 'EditArticle',
          component: articleEdit
        }
      ]
    }

實(shí)際演示

博客前臺(tái)演示頁(yè)面.gif
后臺(tái)管理頁(yè)面演示.gif

TODO

  • [ ] 增加登錄/注冊(cè)功能
  • [ ] 前臺(tái)展示頁(yè)面UI重新設(shè)計(jì)娱局,完善細(xì)節(jié)
  • [ ] 部署到云服務(wù)器上
  • [ ] 移動(dòng)端適配

本項(xiàng)目持續(xù)更新彰亥,如果對(duì)你有所幫助,歡迎到github上點(diǎn)個(gè)star :)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末铃辖,一起剝皮案震驚了整個(gè)濱河市剩愧,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌娇斩,老刑警劉巖仁卷,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異犬第,居然都是意外死亡锦积,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門歉嗓,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)丰介,“玉大人,你說(shuō)我怎么就攤上這事鉴分∠保” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵志珍,是天一觀的道長(zhǎng)橙垢。 經(jīng)常有香客問(wèn)我,道長(zhǎng)伦糯,這世上最難降的妖魔是什么柜某? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮敛纲,結(jié)果婚禮上喂击,老公的妹妹穿的比我還像新娘。我一直安慰自己淤翔,他們只是感情好翰绊,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著旁壮,像睡著了一般辞做。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上寡具,一...
    開(kāi)封第一講書(shū)人閱讀 49,764評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音稚补,去河邊找鬼童叠。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的厦坛。 我是一名探鬼主播五垮,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼杜秸!你這毒婦竟也來(lái)了放仗?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤撬碟,失蹤者是張志新(化名)和其女友劉穎诞挨,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體呢蛤,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡惶傻,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了其障。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片银室。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖励翼,靈堂內(nèi)的尸體忽然破棺而出蜈敢,到底是詐尸還是另有隱情,我是刑警寧澤汽抚,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布抓狭,位于F島的核電站,受9級(jí)特大地震影響殊橙,放射性物質(zhì)發(fā)生泄漏辐宾。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一膨蛮、第九天 我趴在偏房一處隱蔽的房頂上張望叠纹。 院中可真熱鬧,春花似錦敞葛、人聲如沸誉察。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)持偏。三九已至,卻和暖如春氨肌,著一層夾襖步出監(jiān)牢的瞬間鸿秆,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工怎囚, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留卿叽,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像考婴,于是被迫代替她去往敵國(guó)和親贩虾。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容