欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

websocket+node.js實現(xiàn)實時聊天系統(tǒng)問題咨詢

 更新時間:2017年05月17日 14:32:56   作者:蘇黎世寶貝  
最近新學習websocket,做了一個實時聊天。用Node.js搭建的服務(wù):serevr.js. 兩個相互通信頁面:client.html 和server.html 但是就是有很多問題,下面通過本文給大家分享下

1.最近新學習websocket。做了一個實時聊天。用Node.js搭建的服務(wù):serevr.js. 兩個相互通信頁面:client.html 和server.html

但是就是有很多問題,想讓知道的人幫我看看哈:

我先把代碼貼出來:

server.js:

var ws=require("nodejs-websocket");
 console.log("開始建立連接...");
 var str1=null,str2=null, clientReady=false,serverReady=false;
 var server=ws.createServer(function(conn){
   conn.on('text',function(str){
     console.log(str);
     /**
      * 用戶小雨第一次連接
      */
    if(str==="小雨"){
       str1=conn;
       clientReady=true;
       str1.sendText("歡迎"+str); 
    }
    /**
     * 用戶小喬第一次連接
     */
    if(str==="小喬"){
       str2=conn;
       serverReady=true;
      str2.sendText("歡迎"+str);
    }
    /**
     * 當有第二個用戶連接時。
     */
     if(clientReady&&serverReady){
      str2.sendText(str);
      str1.sendText(str);
    }
   })
   conn.on("close",function(code,reason){
     console.log("關(guān)閉連接");
   })
   conn.on("error",function(code,reason){
     console.log("異常關(guān)閉")
   });
 }).listen(8082);
 console.log("websocket連接完畢")
client.html:
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
  <style>
    .kuang{
      width: 600px;
      min-height: 50px;
      max-height:296px;
      border:1px solid;
      float: left;
      display: block;
      position:relative;
      overflow-y: scroll;
    }
    .value{ 
      width: 200px;
    }
    .input{
      display:block;
      position: absolute;
      left:0;
      margin-top: 300px;
    }
  </style>
</head>
<body>
  <label>連接用戶:</label>
  <input type="text" id="name" value="小雨" readonly/>
  <button id="conn">連接</button>
  <button id="close">斷開</button><br/><br/>
  <div class="kuang" id="mess"></div>
  <div class="input"> 
  <input type="text" class="value" id="value1" />
  <button id="send">發(fā)送</button>
  </div>
  <script>
    var name=document.getElementById("name").value;
    var mess=document.getElementById("mess");
    var value1=document.getElementById("value1");
    var conn= document.getElementById("conn");
    var close=document.getElementById("close");
    close.disabled=true;
    if(window.WebSocket){
     conn.onclick=function(){
      var ws=new WebSocket('ws://127.0.0.1:8082');
      conn.disabled=true;
      close.disabled=false; 
       ws.onopen=function(e){
          console.log("連接服務(wù)器成功"); 
           ws.send(name);
      } 
    ws.onmessage=function(e){
      var time=new Date();
      mess.innerHTML+=time.toUTCString()+":"+e.data+"<br>";
      document.getElementById("send").onclick=function(e){
        ws.send(name+"說:"+value1.value);
        value1.value=" ";
      }
      document.onkeydown = function(e) {
        e = e || window.event;
        if(e.keyCode == 13) {
           document.getElementById("send").onclick();
          return false;
        }
      }  
    }
    /**
     * 客戶端主動斷開連接
     * 
     * **/ 
    close.onclick=function(){
      ws.onclose();
      conn.disabled=false;
      close.disabled=true; 
    }  
     ws.onclose = function(e){
       console.log("服務(wù)器關(guān)閉");
     } 
    ws.onerror = function(){
      console.log("連接出錯");
    }
    }  
  }
  </script>
</body>
</html>

server.html 頁面和client.html的代碼一樣,就是用戶名字換成小喬啦。

接下來就是問題啦:

1.運行界面:

  client.html  連接以后:

本來服務(wù)器只需要回傳一個歡迎小雨的,然后下面還輸出了一個。

server.html  小喬連接以后也出來了一個小喬,按理是歡迎小喬。然后告訴小喬小雨在線了。

2.兩個頁面代碼一樣,但是就是不能只變成一個頁面,硬要兩個才能聊天。

3.server.js那邊邏輯有點問題,一直理不清楚。

以上所述是小編給大家介紹的websocket+node.js實現(xiàn)實時聊天系統(tǒng)問題咨詢,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • node.js部署之啟動后臺運行forever的方法

    node.js部署之啟動后臺運行forever的方法

    今天小編就為大家分享一篇node.js部署之啟動后臺運行forever的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Node.js異步I/O學習筆記

    Node.js異步I/O學習筆記

    這篇文章主要介紹了Node.js異步I/O學習筆記,本文詳細講解了異步I/O的基本概念、Node的異步I/O、非I/O的異步API、事件驅(qū)動與高性能服務(wù)器等內(nèi)容,需要的朋友可以參考下
    2014-11-11
  • node刪除、復(fù)制文件或文件夾示例代碼

    node刪除、復(fù)制文件或文件夾示例代碼

    這篇文章主要給大家介紹了關(guān)于node刪除、復(fù)制文件或文件夾的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用node具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • 使用pify實現(xiàn)Node.js回調(diào)函數(shù)的Promise化

    使用pify實現(xiàn)Node.js回調(diào)函數(shù)的Promise化

    使用pify庫,你可以非常便利地將任何遵循Node.js回調(diào)風格的函數(shù)轉(zhuǎn)換為返回Promise對象的函數(shù),從而使得你的異步代碼更加清晰和易于維護,本文通過豐富的代碼示例引導(dǎo)你如何有效地利用pify,需要的朋友可以參考下
    2024-06-06
  • Node.js中如何合并兩個復(fù)雜對象詳解

    Node.js中如何合并兩個復(fù)雜對象詳解

    下面這篇文章主要給大家介紹了在Node.js中如何合并兩個復(fù)雜對象的方法,文中給出了詳細的示例代碼,相信對大家的理解和學習具有一定的參考借鑒價值,有需要的朋友可以參考,下面來一起看看吧。
    2016-12-12
  • NodeJS配置CORS實現(xiàn)過程詳解

    NodeJS配置CORS實現(xiàn)過程詳解

    這篇文章主要介紹了NodeJS配置CORS實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-12-12
  • node.js開機自啟動腳本文件

    node.js開機自啟動腳本文件

    這篇文章主要介紹了node.js開機自啟動腳本文件的方法和代碼,這里分享給大家,有需要的小伙伴參考下吧
    2014-12-12
  • Nodejs模塊載入運行原理

    Nodejs模塊載入運行原理

    本篇文章給大家詳細分享了Nodejs模塊載入運行原理知識點,對此有興趣的朋友可以跟著小編一起學習下。
    2018-02-02
  • 使用Node.js創(chuàng)建本地HTTP服務(wù)器并實現(xiàn)異地遠程訪問的方法

    使用Node.js創(chuàng)建本地HTTP服務(wù)器并實現(xiàn)異地遠程訪問的方法

    Node.js 是能夠在服務(wù)器端運行 JavaScript 的開放源代碼、跨平臺運行環(huán)境,這篇文章主要介紹了如何使用Node.js快速創(chuàng)建本地HTTP服務(wù)器并實現(xiàn)異地遠程訪問,需要的朋友可以參考下
    2024-01-01
  • node+express+ejs使用模版引擎做的一個示例demo

    node+express+ejs使用模版引擎做的一個示例demo

    本篇文章主要介紹了node+express+ejs使用模版引擎做的一個示例demo,具有一定參考價值,有興趣的小伙伴可以了解一下
    2017-09-09

最新評論