国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看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
主站蜘蛛池模板: 亚洲精品久久久久中文字幕欢迎你 | 免费a网站 | 国产精品99久久久久久久vr | 欧美日韩一级视频 | 亚洲视频1区 | 思热99re视热频这里只精品 | 尤物视频在线观看 | 夜操| 亚洲一区二区中文 | 久久亚洲天堂 | 黄色美女在线观看 | 日韩免费av | 国产精品视频免费观看 | 亚洲一本 | 中文字幕在线观看一区二区三区 | 自拍偷拍第一页 | 亚洲国产精品福利 | 国产精品精品 | 综合网伊人 | 精品一二三区 | 97精品超碰一区二区三区 | 国精品一区二区三区 | 高清免费在线 | 四色成人av永久网址 | 91综合网| 久久免费精品国产 | 波多野结衣一区二区三区 | www.中文字幕.com | 国产区在线 | 中文字幕在线免费看 | 久久精品1区 | 91综合在线 | 午夜影剧院| 日韩精品视频在线 | 亚洲电影在线观看 | 亚洲国产区 | 久久精品99| 天堂一区二区三区 | 国产免费天天看高清影视在线 | 黄色影视 | av中文字幕第一页 |