使用socket.io实现简单聊天室案例


Posted in Javascript onJanuary 02, 2018

本文实例为大家分享了socket.io实现简单聊天室的具体代码,供大家参考,具体内容如下

1、客户端【index.html】代码:

<body>
  <h3>socket简例</h3>
  <hr>
  <div id = 'app'>
    <div>
      <div>
        <ul>
          <li v-for = 'item in msgs'>
            {{item.name}}说:{{item.content}}
          </li>
        </ul>
      </div>
      <div>
        <p><input type="text" v-model = 'msg'><button @click = 'm_send()'>发送</button></p>
      </div>
    </div>
  </div>

  <script type="text/javascript" src = 'https://cdn.bootcss.com/vue/2.5.9/vue.min.js'></script>
  <script type="text/javascript" src = 'https://cdn.bootcss.com/socket.io/1.7.3/socket.io.min.js'></script>
  <script type="text/javascript">

    var _vm = new Vue({
      data : {
        name : '用户',
        msg : '',
        msgs : [],
      },
      methods : {
        m_send : function() {

          // 向客户端发送消息
          socket_client.emit('say_client', {
            name : this.name,
            content : this.msg
          }) ;
          this.msg = '' ;
        }
      }
    }).$mount('#app') ;


    // socket服务器
    var socket_client = io.connect('http://127.0.0.1:3000') ; 

    /**
     * 监听服务端发来的消息
     *
     * 1、“say_server”是客户端发出信息时的key值
     * 2、“res”是客户端传来的value值
     */ 
    socket_client.on('say_server' ,function(res){

      console.log('服务端发来的消息为:', res) ;

      _vm.msgs.push(res);
    });

  </script>
</body>

2、服务端【app.js】代码:

const http = require('http') ;
const server = http.createServer() ;

// web服务器
const express = require('express') ;
const app = express();

app.use(express.static(__dirname + '/public'));

app.listen(8888, function () {
  console.log('web服务器成功启动了,IP:127.0.0.1,端口号:8888') ;
});


// socket服务器

const socketio = require('socket.io') ;
const socket_server = socketio(server) ;

// 建立和客户端的socket连接
socket_server.on('connection', function(client) {

// console.log(client) ;          // 查看连接进来的客户端对象内容  
// console.log(Object.keys(client)) ;    // 查看连接进来的客户端对象的关键key值

  /**
   * 监听客户端发来的消息
   *
   * 1、“say_client”是客户端发出信息时的key值
   * 2、“res”是客户端传来的value值
   */ 
  client.on('say_client', function(res) {
    console.log('客户端发来的消息为:', res) ;

    // 向客户端发送消息
    socket_server.emit('say_server', res) ;
  }) ;
}) ;


server.listen(3000, function() {
  console.log('socket服务器成功启动了,IP:127.0.0.1,端口号:3000') ;  
}) ;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery插件NProgress.js制作网页加载进度条
Jun 05 Javascript
javascript获取select值的方法分析
Jul 02 Javascript
Clipboard.js 无需Flash的JavaScript复制粘贴库
Oct 02 Javascript
Node.js实用代码段之正确拼接Buffer
Mar 17 Javascript
20分钟打造属于你的Bootstrap站点
Jul 27 Javascript
什么是JavaScript注入攻击?
Sep 14 Javascript
Vue CLI 3搭建vue+vuex最全分析(推荐)
Sep 27 Javascript
浅谈VueJS SSR 后端绘制内存泄漏的相关解决经验
Dec 20 Javascript
详解解决小程序中webview页面多层history返回问题
Aug 20 Javascript
Jquery 动态添加元素并添加点击事件实现过程解析
Oct 12 jQuery
vue从后台渲染文章列表以及根据id跳转文章详情详解
Dec 14 Vue.js
Vue实现图书管理案例
Jan 20 Vue.js
使用socket.io制做简易WEB聊天室
Jan 02 #Javascript
AngularJS实现的简单拖拽功能示例
Jan 02 #Javascript
AngularJS实现的锚点楼层跳转功能示例
Jan 02 #Javascript
jQuery实现手机号正则验证输入及自动填充空格功能
Jan 02 #jQuery
Node实战之不同环境下配置文件使用教程
Jan 02 #Javascript
jQuery动态添加元素无法触发绑定事件的解决方法分析
Jan 02 #jQuery
Node解决简单重复问题系列之Excel内容的获取
Jan 02 #Javascript
You might like
PHP学习笔记之数组篇
2011/06/28 PHP
php 操作数组(合并,拆分,追加,查找,删除等)
2012/07/20 PHP
php中curl和file_get_content的区别
2014/05/10 PHP
PHP使用zlib扩展实现GZIP压缩输出的方法详解
2018/04/09 PHP
javascript 计算两个整数的百分比值
2009/12/26 Javascript
jquery中使用$(#form).submit()重写提交表单无效原因分析及解决
2013/03/25 Javascript
js去除空格的12种实用方法
2013/11/08 Javascript
js获取和设置属性的方法
2014/02/20 Javascript
JavaScript中跨域调用Flash的方法
2014/08/11 Javascript
JavaScript判断表单为空及获取焦点的方法
2016/02/12 Javascript
全面解析Bootstrap中tooltip、popover的使用方法
2016/06/13 Javascript
js模仿微信朋友圈计算时间显示几天/几小时/几分钟/几秒之前
2017/04/27 Javascript
解决百度Echarts图表坐标轴越界的方法
2018/10/17 Javascript
JavaScript实现图片的放大缩小及拖拽功能示例
2019/05/14 Javascript
简单使用webpack打包文件的实现
2019/10/29 Javascript
python向字符串中添加元素的实例方法
2019/06/28 Python
Python:Numpy 求平均向量的实例
2019/06/29 Python
Django Channels 实现点对点实时聊天和消息推送功能
2019/07/17 Python
python conda操作方法
2019/09/11 Python
python 基于dlib库的人脸检测的实现
2019/11/08 Python
Python selenium 加载并保存QQ群成员,去除其群主、管理员信息的示例代码
2020/05/28 Python
Python 使用xlwt模块将多行多列数据循环写入excel文档的操作
2020/11/10 Python
英国领先的在线礼品店:Getting Personal
2019/09/24 全球购物
大学学习生活感言
2014/01/18 职场文书
乡村文明行动实施方案
2014/03/29 职场文书
市场推广策划方案
2014/06/02 职场文书
计划生育宣传标语
2014/06/21 职场文书
党委班子剖析材料
2014/08/21 职场文书
电子表的操作介绍说明书
2019/10/28 职场文书
高端收音机+蓝牙音箱,JBL TUNER FM带收音蓝牙音箱评测
2021/04/24 无线电
用python修改excel表某一列内容的操作方法
2021/06/11 Python
用Python爬取某乎手机APP数据
2021/06/15 Python
SpringCloud之@FeignClient()注解的使用方式
2021/09/25 Java/Android
Golang数据类型和相互转换
2022/04/12 Golang
python游戏开发Pygame框架
2022/04/22 Python
Windows server 2012 NTP时间同步的实现
2022/06/25 Servers