亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

nodejs實現的一個簡單聊天室功能分享

2019-11-20 13:48:21
字體:
來源:轉載
供稿:網友

今天我來實現一個簡單的聊天室,后臺用nodejs, 客戶端與服務端通信用socket.io,這是一個比較成熟的websocket框架.

初始工作

1.安裝express, 用這個來托管socket.io,以及靜態頁面,命令npm install express --save,--save可以使包添加到package.json文件里.
2.安裝socket.io,命令npm install socket.io --save.

編寫服務端代碼

首先我們通過express來托管網站,并附加到socket.io實例里,因為socket.io初次連接需要http協議

復制代碼 代碼如下:

var express = require('express'),
    io = require('socket.io');

var app = express();

app.use(express.static(__dirname));

var server = app.listen(8888);


var ws = io.listen(server);


添加服務器連接事件,當客戶端連接成功之后,發公告告訴所有在線用戶,并且,當用戶發送消息時,發廣播通知其它用戶.
復制代碼 代碼如下:

ws.on('connection', function(client){
    console.log('/033[96msomeone is connect/033[39m /n');
    client.on('join', function(msg){
        // 檢查是否有重復
        if(checkNickname(msg)){
            client.emit('nickname', '昵稱有重復!');
        }else{
            client.nickname = msg;
            ws.sockets.emit('announcement', '系統', msg + ' 加入了聊天室!');
        }
    });
    // 監聽發送消息
    client.on('send.message', function(msg){
        client.broadcast.emit('send.message',client.nickname,  msg);
    });
    // 斷開連接時,通知其它用戶
    client.on('disconnect', function(){
        if(client.nickname){
            client.broadcast.emit('send.message','系統',  client.nickname + '離開聊天室!');
        }
    })

})

由于客戶端是通過昵稱來標識的,所以服務端需要一個檢測昵稱重復的函數

復制代碼 代碼如下:

// 檢查昵稱是否重復
var checkNickname = function(name){
    for(var k in ws.sockets.sockets){
        if(ws.sockets.sockets.hasOwnProperty(k)){
            if(ws.sockets.sockets[k] && ws.sockets.sockets[k].nickname == name){
                return true;
            }
        }
    }
    return false;
}

編寫客服端代碼

由于服務端采用第三方websokcet框架,所以前端頁面需要單獨引用socket.io客戶端代碼,源文件可以從socket.io模塊里找,windows下路徑為node_modules/socket.io/node_modules/socket.io-client/dist,這里有開發版和壓縮版的,默認引用開發版就行.

前端主要處理輸入昵稱檢查,消息處理,完整代碼如下:

復制代碼 代碼如下:

<!DOCTYPE html>
<html>
<head>
    <title>socket.io 聊天室例子</title>
    <meta charset="utf-8">
    <link rel="stylesheet" href="css/reset.css"/>
    <link rel="stylesheet" href="css/bootstrap.css"/>
    <link rel="stylesheet" href="css/app.css"/>
</head>
<body>
    <div class="wrapper">
         <div class="content" id="chat">
             <ul id="chat_conatiner">
             </ul>
         </div>
         <div class="action">
             <textarea ></textarea>
             <button class="btn btn-success" id="clear">清屏</button>
             <button class="btn btn-success" id="send">發送</button>
         </div>
    </div>
    <script type="text/javascript" src="js/socket.io.js"></script>
    <script type="text/javascript">

          var ws = io.connect('http://172.16.2.184:8888');
          var sendMsg = function(msg){
              ws.emit('send.message', msg);
          }
          var addMessage = function(from, msg){
              var li = document.createElement('li');
              li.innerHTML = '<span>' + from + '</span>' + ' : ' + msg;
              document.querySelector('#chat_conatiner').appendChild(li);

              // 設置內容區的滾動條到底部
              document.querySelector('#chat').scrollTop = document.querySelector('#chat').scrollHeight;

              // 并設置焦點
              document.querySelector('textarea').focus();

          }

          var send = function(){
              var ele_msg = document.querySelector('textarea');
              var msg = ele_msg.value.replace('/r/n', '').trim();
              console.log(msg);
              if(!msg) return;
              sendMsg(msg);
              // 添加消息到自己的內容區
              addMessage('你', msg);
              ele_msg.value = '';
          }

          ws.on('connect', function(){
              var nickname = window.prompt('輸入你的昵稱!');
              while(!nickname){
                  nickname = window.prompt('昵稱不能為空,請重新輸入!')
              }
              ws.emit('join', nickname);
          });

          // 昵稱有重復
          ws.on('nickname', function(){
              var nickname = window.prompt('昵稱有重復,請重新輸入!');
              while(!nickname){
                  nickname = window.prompt('昵稱不能為空,請重新輸入!')
              }
              ws.emit('join', nickname);
          });

          ws.on('send.message', function(from, msg){
              addMessage(from, msg);
          });

          ws.on('announcement', function(from, msg){
              addMessage(from, msg);
          });

          document.querySelector('textarea').addEventListener('keypress', function(event){
              if(event.which == 13){
                  send();
              }
          });
          document.querySelector('textarea').addEventListener('keydown', function(event){
              if(event.which == 13){
                  send();
              }
          });
          document.querySelector('#send').addEventListener('click', function(){
              send();
          });

          document.querySelector('#clear').addEventListener('click', function(){
              document.querySelector('#chat_conatiner').innerHTML = '';
          });
    </script>
</body>
</html>

這里提供完整的代碼壓縮文件

總結

nodejs是一個好東西,尤其是在處理消息通訊,網絡編程方面,天生的異步IO.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久国产精品三级玉女聊斋| 亚洲男人的天堂在线| 国产精品永久在线| 国产精品主播视频| 亚洲欧美精品伊人久久| 欧美伊久线香蕉线新在线| 91在线观看欧美日韩| 久久久久久国产免费| 欧美亚洲一级片| 久久精品久久精品亚洲人| 成人黄色av播放免费| 91在线观看免费| 九九视频这里只有精品| 亚洲国产日韩欧美在线图片| 国产在线视频欧美| 亚洲综合精品一区二区| 欧美激情精品久久久久久变态| 97婷婷涩涩精品一区| 色综合影院在线| 日韩禁在线播放| 亚洲一区二区三| 国产69精品久久久| 成人国产在线激情| 国产精品自在线| zzijzzij亚洲日本成熟少妇| 久久影视电视剧免费网站清宫辞电视| 国产精品福利片| 国产97人人超碰caoprom| 欧美大胆在线视频| 欧美自拍大量在线观看| 欧美一区二区三区免费观看| 一本大道香蕉久在线播放29| 狠狠躁夜夜躁人人躁婷婷91| 97国产精品视频| 亚洲欧美自拍一区| 影音先锋欧美在线资源| 欧美激情中文字幕乱码免费| 中文字幕日韩在线视频| 欧美激情国产日韩精品一区18| 中文字幕在线观看亚洲| 97精品欧美一区二区三区| 欧美体内谢she精2性欧美| 欧美一级高清免费播放| 日韩免费视频在线观看| 92裸体在线视频网站| 不卡在线观看电视剧完整版| 日韩精品日韩在线观看| 日韩一区二区欧美| 亚洲精品综合精品自拍| 国产成人精品免费视频| 98精品在线视频| 国产亚洲精品综合一区91| 亚洲欧美三级在线| 九九九久久国产免费| 自拍亚洲一区欧美另类| 在线电影中文日韩| 日韩国产高清污视频在线观看| 成人欧美一区二区三区黑人| 亚洲国产成人精品久久久国产成人一区| 欧美亚洲国产精品| 欧美性猛交99久久久久99按摩| 亚洲国产91色在线| 美女福利精品视频| www.日韩不卡电影av| 成人免费看吃奶视频网站| 91免费看片在线| 高清一区二区三区四区五区| 91在线免费观看网站| 国产精品中文字幕在线观看| 精品久久久久久久久久| 主播福利视频一区| 国产精品三级久久久久久电影| 亚洲图片制服诱惑| 日韩久久免费视频| 插插插亚洲综合网| 国产精品亚洲自拍| 国产精品永久免费| 亚洲级视频在线观看免费1级| 日韩欧美综合在线视频| 国产成人97精品免费看片| 久久久久久久久久国产精品| 欧美尺度大的性做爰视频| 精品久久香蕉国产线看观看亚洲| 国产亚洲精品美女| 国产日韩在线一区| 日本最新高清不卡中文字幕| 日韩av综合网| 91在线色戒在线| 成人久久一区二区| 日韩在线免费高清视频| 91亚洲精品一区| 欧美一区二粉嫩精品国产一线天| 欧美午夜片在线免费观看| 国产精品草莓在线免费观看| 日本亚洲欧美成人| 亚洲免费av网址| 欧美午夜视频一区二区| 69影院欧美专区视频| 色七七影院综合| 欧美日韩加勒比精品一区| 欧美乱大交做爰xxxⅹ性3| 日韩欧美一区二区三区久久| 亚洲free性xxxx护士白浆| 黑人极品videos精品欧美裸| 激情久久av一区av二区av三区| 国语自产精品视频在线看| 精品无人区太爽高潮在线播放| 亚洲免费福利视频| 亚洲人a成www在线影院| 亚洲精品国产美女| 九色成人免费视频| 国产成人一区二区三区小说| 国产97色在线|日韩| 78色国产精品| 国产精品久久久久9999| 欧美视频国产精品| 一区二区在线视频| 久久九九国产精品怡红院| 久久久久一本一区二区青青蜜月| 欧美性高潮床叫视频| 黑人精品xxx一区一二区| 91精品国产91久久久久久最新| 国产精品福利片| 日韩欧美亚洲一二三区| 欧美成人精品一区| 日韩精品在线观| 亚洲国内高清视频| 久久天天躁狠狠躁老女人| 上原亚衣av一区二区三区| 91精品国产免费久久久久久| 日韩有码在线视频| 成人亲热视频网站| 欧美一区二区三区免费视| 欧美日韩国产一区在线| 国产精品偷伦免费视频观看的| 在线观看国产精品淫| 精品亚洲国产视频| 狠狠色狠色综合曰曰| 日韩在线观看av| 亚洲精品videossex少妇| 不卡av电影院| 亚洲国产天堂久久综合| 亚洲国产精品电影在线观看| 91精品国产91久久久久久最新| 国产精品男人爽免费视频1| 久久精品99久久久久久久久| 黄色91在线观看| 欧美激情一区二区三区在线视频观看| 亚洲一区第一页| 国产精品三级美女白浆呻吟| 欧美国产日韩在线| 亚洲一区中文字幕| 欧美野外猛男的大粗鳮| 亚洲国产精品一区二区三区| 亚洲精品网站在线播放gif| 亚洲电影免费观看高清完整版| 在线视频中文亚洲| 秋霞午夜一区二区| 国产偷国产偷亚洲清高网站| 国产精品白丝jk喷水视频一区| 欧美久久精品午夜青青大伊人| 欧亚精品中文字幕| 在线国产精品视频| 亚洲一区二区久久久久久|