VueSocial(vue+express+socket.io仿微博、微信的聊天社交平臺)

VueSocial

something like QQ报咳、weibo侠讯、weixin(仿微博、微信的聊天社交平臺)前后端分離的vue+express+socket.io練手項目


內(nèi)容

  1. 預(yù)覽

  2. 技術(shù)棧

  3. 已實現(xiàn)功能

  4. 待改進(jìn)

  5. 安裝

  6. 項目部分圖片

  7. 分析總結(jié)

預(yù)覽

在線demo (移動端無法打開請復(fù)制地址使用瀏覽器打開少孝,pc端按了f12后有個小問題继低,刷新一下就好,resize觸發(fā)的問題,待改進(jìn))http://47.107.66.252:3001/public/dist/#/home

github地址


技術(shù)棧

  1. vue:前端框架

  2. express:后端框架

  3. socket.io:實現(xiàn)實時消息推送

  4. axios:一個基于 Promise 的 HTTP 庫稍走,發(fā)送ajax請求

  5. localStorage:瀏覽器本地存儲

  6. Webpack:模塊打包工具,前端項目構(gòu)建工具

  7. mongoose:mongodb的框架

  8. better-scroll:一款重點解決移動端(已支持 PC)各種滾動場景需求的插件


已實現(xiàn)功能

  1. 登錄注冊

  2. 圖片分享:上傳本地圖片到云服務(wù)器(我用的是阿里云的oss柴底,可以根據(jù)自己的情況修改router/upload.js的代碼)

  3. 頭像修改

  4. 評論:socket.io

  5. 實時消息推送

  6. 查看個人主頁

  7. 實時聊天:socket.io

  8. 首頁下拉刷新:better-scroll

  9. 搜索:搜索用戶與動態(tài)婿脸、使用localStorage保存歷史搜索記錄


待改進(jìn)

  1. 同一個用戶多個設(shè)備同時登錄時socket.io會出現(xiàn)問題,所以要限制登錄柄驻?還是修改數(shù)據(jù)庫結(jié)構(gòu)狐树?

  2. 移動端的坑:有的瀏覽器會卡頓、Safari監(jiān)聽不到輸入框按下搜索鍵(內(nèi)心是崩潰的)

  3. resize時better-scroll的小bug

4.沒做分頁請求鸿脓,都是一次性請求全部數(shù)據(jù)


安裝

分別兩個文件目錄下安裝依賴npm install抑钟,在server文件夾下node app.js,在blogPhone下npm run dev,然后打開localhost:8081就可以了


項目部分圖片

首頁

微信圖片_20181118231148.jpg

登錄

微信圖片_20181118231159.jpg

消息

微信圖片_20181118231142.jpg

聊天

微信圖片_20181118231154.jpg

個人信息

微信圖片_20181118231120.jpg

個人主頁

微信圖片_20181118231131.jpg

分享動態(tài)

微信圖片_20181118231054.jpg

更改頭像

微信圖片_20181118231115.jpg

搜索頁面

微信圖片_20181118231126.jpg

微信圖片_20181118231137.jpg

分析總結(jié)

socket.io

服務(wù)端:


  let serve = app.listen(3001);

  const io = socketio(serve);

  io.on('connection', socket => {

    socket.on('login', (username) => {

                console.log(username+'上線了野哭!');

            });

  }

客戶端:

在index中引入


    <script src="http://47.107.66.252:3001/socket.io/socket.io.js"></script>

    <script type="text/javascript">

      const socket = io.connect('http://47.107.66.252:3001');

    </script>

這部分的數(shù)據(jù)庫寫得有點亂(很亂在塔。。拨黔。)蛔溃,但是socket.io的使用其實很方便,無非就是on和emit

socket.emit():向建立該連接的客戶端發(fā)送消息

socket.on():監(jiān)聽客戶端發(fā)送信息

io.to(socketid).emit():向指定客戶端發(fā)送消息

socket.broadcast.emit():向除去建立該連接的客戶端的所有客戶端廣播

io.sockets.emit():向所有客戶端廣播

vue

總結(jié)一些項目遇到的難點

  1. ajax在生命周期函數(shù)created發(fā)起篱蝇,dom操作在生命周期函數(shù)mounted中操作贺待,如果需要dom元素完全掛起后在操作則還需要在$nextTick中操作,例如:

mounted() {

      this.$nextTick(() => {

        this.initImg();

      })

    }

  1. 動態(tài)生成(例如通過v-for)的dom元素在mounted中通過ref是獲取不到的零截,需要在生命周期函數(shù)updated中獲取

  2. keepalive后的組件如果需要在跳轉(zhuǎn)進(jìn)入時進(jìn)行操作可通過路由守衛(wèi)和生命周期函數(shù)actived配合使用麸塞,如:


beforeRouteEnter(to, from, next) {

      if (from.path == '/upload' ) {

        next(vm => {

          vm._getList = true

        })

      } else {

        next()

      }

    }


activated() {

      this.$nextTick(() => {

        if (this._getList) {

          this.getPyqLists();

        }

      })

    }


更新中...

如果覺得這個項目對你有幫助,請留下你的star涧衙,謝謝(^-^)V

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末哪工,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子绍撞,更是在濱河造成了極大的恐慌正勒,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件傻铣,死亡現(xiàn)場離奇詭異章贞,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進(jìn)店門鸭限,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蜕径,“玉大人,你說我怎么就攤上這事败京《涤鳎” “怎么了?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵赡麦,是天一觀的道長朴皆。 經(jīng)常有香客問我,道長泛粹,這世上最難降的妖魔是什么遂铡? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮晶姊,結(jié)果婚禮上扒接,老公的妹妹穿的比我還像新娘。我一直安慰自己们衙,他們只是感情好钾怔,可當(dāng)我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蒙挑,像睡著了一般宗侦。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上脆荷,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天凝垛,我揣著相機(jī)與錄音,去河邊找鬼蜓谋。 笑死梦皮,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的桃焕。 我是一名探鬼主播剑肯,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼观堂!你這毒婦竟也來了让网?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤师痕,失蹤者是張志新(化名)和其女友劉穎溃睹,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體胰坟,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡因篇,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片竞滓。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡咐吼,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出商佑,到底是詐尸還是另有隱情锯茄,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布茶没,位于F島的核電站肌幽,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏礁叔。R本人自食惡果不足惜牍颈,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望琅关。 院中可真熱鬧,春花似錦讥蔽、人聲如沸涣易。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽新症。三九已至,卻和暖如春响禽,著一層夾襖步出監(jiān)牢的瞬間徒爹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工芋类, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留隆嗅,地道東北人。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓侯繁,卻偏偏與公主長得像胖喳,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子贮竟,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,802評論 2 345