使用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 相关文章推荐
js实现单一html页面两套css切换代码
Apr 11 Javascript
js实现div层缓慢收缩与展开的方法
May 11 Javascript
ES6的新特性概览
Mar 10 Javascript
JS小数运算出现多为小数问题的解决方法
Jun 02 Javascript
Angular+Bootstrap+Spring Boot实现分页功能实例代码
Jul 21 Javascript
从vue基础开始创建一个简单的增删改查的实例代码(推荐)
Feb 11 Javascript
详解vue使用vue-layer-mobile组件实现toast,loading效果
Aug 31 Javascript
bootstrap table实现合并单元格效果
Dec 24 Javascript
layui中的switch开关实现方法
Sep 03 Javascript
微信小程序在text文本实现多种字体样式
Nov 08 Javascript
javascript实现点击星星小游戏
Dec 24 Javascript
node.JS路径解析之PATH模块使用方法详解
Feb 06 Javascript
使用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提取中文首字母
2008/04/09 PHP
为PHP安装imagick时出现Cannot locate header file MagickWand.h错误的解决方法
2014/11/03 PHP
Laravel 5.3 学习笔记之 配置
2016/08/28 PHP
简单谈谈PHP中的Reload操作
2016/12/12 PHP
javascript void(0)的妙用
2009/10/21 Javascript
jquery animate图片模向滑动示例代码
2011/01/26 Javascript
javascript 随机展示头像实现代码
2011/12/06 Javascript
最新最热最实用的15个jQuery插件汇总
2015/07/05 Javascript
Jquery基础教程之DOM操作
2015/08/19 Javascript
jquery实现红色竖向多级向右展开的导航菜单效果
2015/08/31 Javascript
TypeScript Type Innference(类型判断)
2016/03/10 Javascript
详解angular2采用自定义指令(Directive)方式加载jquery插件
2017/02/09 Javascript
微信小程序 列表的上拉加载和下拉刷新的实现
2017/04/01 Javascript
three.js加载obj模型的实例代码
2017/11/10 Javascript
mui框架 页面无法滚动的解决方法(推荐)
2018/01/25 Javascript
一次记住JavaScript的6个正则表达式方法
2018/02/22 Javascript
修改node.js默认的npm安装目录实例
2018/05/15 Javascript
vue发送websocket请求和http post请求的实例代码
2019/07/11 Javascript
jquery中attr、prop、data区别与用法分析
2019/09/25 jQuery
js实现录音上传功能
2019/11/22 Javascript
[44:50]DOTA2上海特级锦标赛B组小组赛#2 VG VS Fnatic第二局
2016/02/26 DOTA
python实现从字典中删除元素的方法
2015/05/04 Python
python之matplotlib学习绘制动态更新图实例代码
2018/01/23 Python
Python中的异常处理try/except/finally/raise用法分析
2019/02/28 Python
python小程序实现刷票功能详解
2019/07/17 Python
Python使用grequests(gevent+requests)并发发送请求过程解析
2019/09/25 Python
python中return的返回和执行实例
2019/12/24 Python
毕业生造价工程师求职信
2013/10/17 职场文书
售后主管岗位职责
2013/12/08 职场文书
监理资料员岗位职责
2014/01/03 职场文书
竞选班干部演讲稿500字
2014/08/20 职场文书
2014最新开业庆典策划方案(5篇)
2014/09/15 职场文书
2014年人民调解工作总结
2014/12/08 职场文书
2015年医院工作总结范文
2015/04/09 职场文书
酒店人事主管岗位职责
2015/04/11 职场文书
工程进度款催款函
2015/06/24 职场文书