激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - angularjs - 在Angular項目使用socket.io實現通信的方法

在Angular項目使用socket.io實現通信的方法

2021-12-27 15:55陳仙生 angularjs

這篇文章主要介紹了在Angular項目使用socket.io實現通信的方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

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實現通信內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/qq_45745643/article/details/112173731

延伸 · 閱讀

精彩推薦
  • angularjs教你用AngularJS框架一行JS代碼實現控件驗證效果

    教你用AngularJS框架一行JS代碼實現控件驗證效果

    簡單來說Angular.js是google開發者設計和開發的一套前端開發框架,幫助你簡化前端開發的負擔。到底能簡化到什么程度呢,今天我們來看下,一行代碼實現控...

    AngularJS教程網8012022-01-03
  • angularjsangularjs實現與服務器交互分享

    angularjs實現與服務器交互分享

    AngularJS是Google開發的純客戶端JavaScript技術的WEB框架,用于擴展、增強HTML功能,它專為構建強大的WEB應用而設計。...

    angularjs教程網7312022-01-03
  • angularjsAngular框架詳解之視圖抽象定義

    Angular框架詳解之視圖抽象定義

    這篇文章主要給大家介紹了關于Angular框架詳解之視圖抽象定義的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習...

    被刪6782022-02-24
  • angularjsAngularJS 中括號的作用詳解

    AngularJS 中括號的作用詳解

    這篇文章主要介紹了AngularJS 中括號的作用,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下...

    Java Pro8652022-02-22
  • angularjsangularJS提交表單(form)

    angularJS提交表單(form)

    這篇文章主要介紹了angularJS提交表單(form)的方法和示例,需要的朋友可以參考下...

    angularJS教程網3972022-01-03
  • angularjsAngular.JS中指令的命名規則詳解

    Angular.JS中指令的命名規則詳解

    這篇文章主要給大家介紹了關于Angular.JS中指令命名規則的相關資料,文中介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看...

    劉小光10402022-01-17
  • angularjsangularJS 中input示例分享

    angularJS 中input示例分享

    這篇文章主要介紹了angularJS 中input示例分享,需要的朋友可以參考下...

    angularJS教程網5652022-01-03
  • angularjsangularJS中router的使用指南

    angularJS中router的使用指南

    這篇文章主要介紹了angularJS中router的使用方法和示例分享,需要的朋友可以參考下...

    angularJS教程網8372022-01-03
主站蜘蛛池模板: 久久草草亚洲蜜桃臀 | 国产精品久久久久久影视 | 久久丝袜脚交足黄网站免费 | 久久亚洲精品久久国产一区二区 | asian裸体佳人pics | 麻豆视频网 | 中文字幕11| 国产高清在线观看av | 午夜天堂在线视频 | 九九热视频在线 | 美女黄网站免费观看 | 亚洲成人福利网站 | 亚洲国产精品久久久久久久 | 久久网国产精品 | 日韩精品一二三区 | 国产日产精品一区二区三区四区 | 少妇一级淫片免费放播放 | 久久久精品精品 | 91专区在线观看 | 伊人yinren22综合网色 | 性少妇videosexfreexx | 天天干天天透 | 欧美一级在线免费 | 国产在线久 | 久久亚洲线观看视频 | 一色桃子av大全在线播放 | 久久人人爽爽爽人久久久 | 久久久久久久一区二区三区 | 欧美一级淫片免费视频1 | 成人不卡一区二区 | 久久爽精品区穿丝袜 | 国产午夜精品理论片a级探花 | 久久国产中文 | 日本在线观看视频网站 | 日韩黄色免费电影 | 午夜视频免费在线观看 | 中文字幕激情 | 欧洲精品久久 | 亚州视频在线 | 嗯~啊~弄嗯~啊h高潮视频 | 中文字幕在线永久视频 |