在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 相关文章推荐
Windows Live的@live.com域名注册漏洞 利用代码
Dec 27 Javascript
jQuery学习4 浏览器的事件模型
Feb 07 Javascript
js中的eventType事件及其浏览器支持性介绍
Nov 29 Javascript
js数值和和字符串进行转换时可以对不同进制进行操作
Mar 05 Javascript
js判断iframe内的网页是否滚动到底部触发事件
Mar 18 Javascript
js数组的五种迭代方法及两种归并方法(推荐)
Jun 14 Javascript
React-router中结合webpack实现按需加载实例
May 25 Javascript
用p5.js制作烟花特效的示例代码
Mar 21 Javascript
让axios发送表单请求形式的键值对post数据的实例
Aug 11 Javascript
Vue组件间通信 Vuex的用法解析
Aug 05 Javascript
微信小程序实现页面分享onShareAppMessage
Aug 12 Javascript
微信小程序云函数添加数据到数据库的方法
Mar 04 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
3.从实例开始
2006/10/09 PHP
php截取utf-8中文字符串乱码的解决方法
2010/03/29 PHP
Thinkphp将二维数组变为标签适用的一维数组方法总结
2014/10/30 PHP
php简单获取文件扩展名的方法
2015/03/24 PHP
Yii扩展组件编写方法实例分析
2015/06/29 PHP
在PHP站点的页面上添加Facebook评论插件的实例教程
2016/01/08 PHP
PHP查询大量数据内存耗尽问题的解决方法
2016/10/28 PHP
PHP实现微信红包金额拆分试玩的算法示例
2018/04/07 PHP
js实现的网页颜色代码表全集
2007/07/17 Javascript
Jquery图片延迟加载插件jquery.lazyload.js的使用方法
2014/05/21 Javascript
node.js中的path.basename方法使用说明
2014/12/09 Javascript
jQuery中slideUp 和 slideDown 的点击事件
2015/02/26 Javascript
jquery插件bxslider用法实例分析
2015/04/16 Javascript
JS实现仿微博可关闭弹出层效果
2015/09/21 Javascript
jQuery.Uploadify插件实现带进度条的批量上传功能
2016/06/08 Javascript
神级程序员JavaScript300行代码搞定汉字转拼音
2017/05/20 Javascript
Three.js利用dat.GUI如何简化试验流程详解
2017/09/26 Javascript
详细分析jsonp的原理和实现方式
2017/11/20 Javascript
用Node提供静态文件服务的方法
2018/07/06 Javascript
基于Vue实现可以拖拽的树形表格实例详解
2018/10/18 Javascript
CountUp.js数字滚动插件使用方法详解
2019/10/17 Javascript
node.js使用yargs处理命令行参数操作示例
2020/02/11 Javascript
Vue 根据条件判断van-tab的显示方式
2020/08/03 Javascript
解决Vue中使用keepAlive不缓存问题
2020/08/04 Javascript
python网络编程学习笔记(六):Web客户端访问
2014/06/09 Python
Python中的魔法方法深入理解
2014/07/09 Python
人机交互程序 python实现人机对话
2017/11/14 Python
Python实现扣除个人税后的工资计算器示例
2018/03/26 Python
PyQt5创建一个新窗口的实例
2019/06/20 Python
python 实现让字典的value 成为列表
2019/12/16 Python
python接口自动化如何封装获取常量的类
2019/12/24 Python
python 实现仿微信聊天时间格式化显示的代码
2020/04/17 Python
幼儿园社区活动总结
2014/07/07 职场文书
幼儿园感恩节活动方案2014
2014/10/11 职场文书
先进党支部申报材料
2014/12/24 职场文书
《没有任何借口》读后感:完美的执行能力
2020/01/07 职场文书