zoukankan      html  css  js  c++  java
  • Vue Node vue-socket.io 联合使用 简易聊天程序

    之前用goEasy写过聊天程序,现在想试试websocket来结合vue玩玩,所以有今天这个随笔####

    安装必要包#####
    //node.js
    
    npm i socket.io --save
    
    //vue
    
    npm i vue-socket.io --save
    npm i socket.io-client --save
    
    配置node.js 创建目录/文件 server/app.js#####

    新增packjson配置,配置后npm run server即可启动#####

    //如果只想要一个命令即启动node服务器,也启动socket,可以把server/app.js引入总的app.js中  使用npm start时就会启动所有服务啦!
    //app.js
    
    var socket  = require('./server/app');
    
    新建app.js内容#####
    var http = require('http');
    var fs = require('fs');
    var exec = require('child_process').exec;
    var server = http.createServer().listen(8888);//创建http服务
    console.log('Server running ');
    var io = require('socket.io').listen(server);
    io.sockets.on('connection', (socket) => {
        console.log('连接成功!!!')
        socket.on('test', (data) => {//这里的test是供前端请求的方法名
            socket.broadcast.emit('test', {//给除了自己以外的客户端广播消息
                nickname: data.nickName,
                id: socket.id,
                massage: data.val
            });
        });
    });
    
    Test.vue文件内容#####
    <template>
        <div>
            <div>我的昵称是:{{myNicakName}}</div>
            <div>
                <input type="text" ref="nikeName">
                <button @click="setMyNicakName">设置我的昵称</button>
            </div>
            <br />
            <div>
                <input type="text" ref="message">
                <button @click="submitVal">发送内容</button>
            </div>
    
            <div>
                <p>聊天内容:</p>
                <ul class="el_content">
                    <!-- <li class="other" v-for="(item, index) in messages" :key="index">他人:
                        <div>{{item}}</div>
                    </li>
                    <li class="my" v-for="item in mySay" :key="item">我:
                        <div>{{item}}</div>
                    </li> -->
                    <li v-for="(item, index) in allMessages" :key="index" :class="item.isMySay == true ? 'my' : 'other'">
                        {{item.isMySay == true ? '我:' : (item.nickname || '匿名') + ':'}}
                        {{item.content}}
                    </li>
                </ul>
            </div>
        </div>
    </template>
    <script>
        export default{
            data(){
                return {
                    myNicakName: '',//设置自己的昵称
                    allMessages: []//所有数据结合
                }
            },
            sockets: {
                // 查看是否连接成功
                connect() {
                    console.log('连接成功啦!!!')
                },
                test(data){//这个test方法是后台提供请求名字,这里调用即可接收数据
                    /**
                     * 参数定义:
                     * isMySay -- 是否是我发送的内容
                     * content -- 消息内容
                     * nickname -- 用户的昵称  没有默认为匿名
                     */
                    var allMessage = {isMySay: false,content:data.massage, nickname: data.nickname}//自定义一个对象,每次触发生成该对象
                    this.allMessages.push(allMessage)//把该对象push到循环的数组中
                }
            },
            methods: {
                /**
                 * 提交信息
                 */
                submitVal(){
                    var val = this.$refs.message.value//提交的内容
                    var nickName = this.myNicakName//用户的昵称
                    var submitVal = {//需要提交的数据
                        val:val,
                        nickName:nickName
                    }
                    var allMessage = {isMySay: true,content:val}//自定义一个对象,每次触发生成该对象
                    this.allMessages.push(allMessage)//把该对象push到循环的数组中
    
                    //前端提交信息给socket test是后台提供的方法名, submitVal是传递过去的内容
                    this.$socket.emit('test', submitVal)
                },
                /**
                 * 设置昵称
                 */
                setMyNicakName(){
                    this.myNicakName = this.$refs.nikeName.value
                }
            }
        }
    </script>
    <style lang="">
    .other{
        text-align: left;
    }
    .my{
        text-align: right;
    }
    </style>
    
    main.js加入代码#####
    import VueSocketio from 'vue-socket.io';
    import socketio from 'socket.io-client';
    Vue.use(new VueSocketio({
      connection: 'http://127.0.0.1:8888/'
    }))
    

    最后效果####


    总结: 
              1.必要步骤node端开启长连接,并可访问
              2.vue正确调用连接方法
              3.自己写入必要的实现逻辑
    

    最后推荐一篇socket功能性文章

  • 相关阅读:
    python操作redis之hash操作
    mongodb数据库分片实现链接
    python连接redis数据库的两种方式
    python操作rabbitmq实现消息过滤接收
    python操作rabbitmq实现广播效果
    关于java和python同时使用rabbitmq时队列同名问题的探讨
    java操作rabbitmq实现简单的消息发送(socket编程的升级)
    python使用rabbitmq实现简单的消息转发
    optiongroup标签选项组
    day05_日常SQL练习(一)
  • 原文地址:https://www.cnblogs.com/yzyh/p/10143972.html
Copyright © 2011-2022 走看看