在Angular项目使用socket.io实现通信的方法


Posted in Javascript onJanuary 05, 2021

step1、为项目安装依赖

在终端输入以下命令为我们的angular项目安装express、socket.io、socket.io-client

npm install express socket.io socket.io-client

本人安装的各版本信息如下:

"express": "^4.17.1",
"socket.io": "^3.0.4",
"socket.io-client": "^3.0.4",

step2、编写后台服务

可以在项目中新建一个server文件夹,用来存放我们的后台服务,然后新建文件

const app = require('express')();
const http = require('http').createServer(app);

const io = require('socket.io')(http, {
 cors: {  // 处理跨域问题
  origin: "http://localhost:4300", // angular项目的启动端口,默认4200,本人项目的启动端口为4300,大家根据自己情况修改
  methods: ["GET", "POST"],
  credentials: true
 }
});

io.on('connection', (socket) => {
 console.log('user connected');

 socket.on('add-message', (message) => {
  io.emit('message', {type: 'new-message', text: message});
 });
})

http.listen(4000, () => { // 后台服务启动端口
 console.log('start on 4000....');
})

step3、创建angular服务

import { Injectable } from '@angular/core';
import { Observable, Subject } from 'rxjs';
import { io } from 'socket.io-client';

@Injectable()
export class ChatService {
 private url = 'http://localhost:4000'; // 后台服务端口
 private socket: any;

 sendMessage(message: any) {
  this.socket.emit('add-message', message);
 }

 getMessages(): Observable<any> {
  return new Observable(observer => {
   this.socket = io(this.url, {withCredentials: true});
   this.socket.on('message', (data) => {
    observer.next(data);
   });
   return () => {
    this.socket.disconnect();
   }
  })
 }
}

这里我们创建了两个方法,sendMessage用于将客户端的信息发送给服务端,getMessages用于建立连接,监听服务端事件并返回一个可观察的对象。

step4、创建组件

import { Component, OnInit, OnDestroy } from '@angular/core';
import { ChatService } from './chat.service';

@Component({
 selector: 'test-chat',
 template: `<div *ngFor="let message of messages">
        {{message.text}}
       </div>
       <input [(ngModel)]="message" />
       <button (click)="sendMessage()">Send</button>`,
 providers: [ChatService] // 注入依赖
})
export class TestChatComponent implements OnInit, OnDestroy {
 messages = [];
 connection: any;
 message: any;

 constructor(private chatService: ChatService) {
 }

 sendMessage() {
  this.chatService.sendMessage(this.message);
  this.message = '';
 }

 ngOnInit() {
  this.connection = this.chatService.getMessages()
   .subscribe(message => {  // 组件初始化时订阅信息
    this.messages.push(message);
   });
 }

 ngOnDestroy() {
  this.connection.unsubscribe();  // 组件销毁取消订阅
 }
}

这样一个简单的socket通信就完成了,效果图如下:

启动服务

在Angular项目使用socket.io实现通信的方法

前端页面

在Angular项目使用socket.io实现通信的方法

在Angular项目使用socket.io实现通信的方法

如果遇到跨域问题,大概率是没有处理跨域,检查自己的代码和端口号是否正确,详情参考handing-cors

另外,如果遇到(本人遇到了,愣是在网上找了半天依然未果)
POST http://localhost:4000/socket.io/?EIO=3&transport=polling&t=NQtz_E3 400 (Bad Request)
这类的报错,npm安装socket.io-client(这也是为什么我在文章一开始就安装它),在service.ts文件引入

import { io } from 'socket.io-client';

在网上看到很多人是这样写的 import * as io from ‘socket.io-client',这种写法在typescript中是会报错的,改成上面的写法即可。

到此这篇关于在Angular项目使用socket.io实现通信的文章就介绍到这了,更多相关Angular使用socket.io实现通信内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
“不能执行已释放的Script代码”错误的原因及解决办法
Sep 09 Javascript
setTimeout()与setInterval()方法区别介绍
Dec 24 Javascript
巧用jquery解决下拉菜单被Div遮挡的相关问题
Feb 13 Javascript
JavaScript中return false的用法
Mar 12 Javascript
Jquery幻灯片特效代码分享--打开页面随机选择切换方式(3)
Aug 15 Javascript
javascript时间排序算法实现活动秒杀倒计时效果
Jan 28 Javascript
jQuery简单实现点击文本框复制内容到剪贴板上的方法
Aug 01 Javascript
vue实现的上传图片到数据库并显示到页面功能示例
Mar 17 Javascript
Angular-UI Bootstrap组件实现警报功能
Jul 16 Javascript
js实现ATM机存取款功能
Oct 27 Javascript
原生JavaScript实现日历功能代码实例(无引用Jq)
Sep 23 Javascript
vue-cli3项目升级到vue-cli4 的方法总结
Mar 19 Javascript
利用JavaScript为句子加标题的3种方法示例
Jan 05 #Javascript
绘制微信小程序验证码功能的实例代码
Jan 05 #Javascript
详解JavaScript中分解数字的三种方法
Jan 05 #Javascript
Vue+scss白天和夜间模式切换功能的实现方法
Jan 05 #Vue.js
mapboxgl实现带箭头轨迹线的代码
Jan 04 #Javascript
jenkins自动构建发布vue项目的方法步骤
Jan 04 #Vue.js
vue3弹出层V3Popup实例详解
Jan 04 #Vue.js
You might like
PHP中的float类型使用说明
2010/07/27 PHP
部署PHP项目应该注意的几点事项分享
2013/12/20 PHP
JS中Iframe之间传值及子页面与父页面应用
2013/03/11 Javascript
代码触发js事件(click、change)示例应用
2013/12/13 Javascript
Javascript学习笔记之 函数篇(三) : 闭包和引用
2014/11/23 Javascript
JavaScript中setMonth()方法的使用详解
2015/06/11 Javascript
详解本地Node.js服务器作为api服务器的解决办法
2017/02/28 Javascript
bootstrap模态框示例代码分享
2017/05/17 Javascript
解决JS外部文件中文注释出现乱码问题
2017/07/09 Javascript
Angular移动端页面input无法输入的解决方法
2017/11/14 Javascript
关于vue编译版本引入的问题的解决
2018/09/17 Javascript
用Python和MD5实现网站挂马检测程序
2014/03/13 Python
python生成指定尺寸缩略图的示例
2014/05/07 Python
Python version 2.7 required, which was not found in the registry
2014/08/26 Python
Python socket C/S结构的聊天室应用实现
2014/11/30 Python
Python bsddb模块操作Berkeley DB数据库介绍
2015/04/08 Python
Python实现读取txt文件并画三维图简单代码示例
2017/12/09 Python
Python使用matplotlib绘制多个图形单独显示的方法示例
2018/03/14 Python
深入了解Django View(视图系统)
2019/07/23 Python
使用python实现数组、链表、队列、栈的方法
2019/12/20 Python
python设置表格边框的具体方法
2020/07/17 Python
详解Flask前后端分离项目案例
2020/07/24 Python
Orvis官网:自1856年以来,优质服装、飞钓装备等
2018/12/17 全球购物
专业实习自我鉴定
2013/10/29 职场文书
办公室驾驶员岗位职责
2013/11/15 职场文书
历史教育专业个人求职信
2013/12/13 职场文书
晚宴邀请函范文
2014/01/15 职场文书
读书伴我成长演讲稿
2014/05/07 职场文书
班级课外活动总结
2014/07/09 职场文书
检察机关个人对照检查材料
2014/09/15 职场文书
校车司机安全责任书
2015/05/11 职场文书
《1942》观后感
2015/06/08 职场文书
雷锋观后感
2015/06/10 职场文书
SpringBoot项目中控制台日志的保存配置操作
2021/06/18 Java/Android
解决vue中provide inject的响应式监听
2022/04/19 Vue.js
mysql序号rownum行号实现方式
2022/12/24 MySQL