Angular应用程序如何知道数据库表的数据/状态被其他应用程序更改,然后需要在组件侧刷新其数据?
创始人
2024-10-30 13:31:04
0

Angular可以使用WebSocket和服务器端推送技术来实现实时的数据更新和通知。这可以通过socket.io来实现。

首先在Angular应用程序中,创建一个WebSocket服务来建立与服务器的WebSocket连接:

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

@Injectable() export class SocketService { private url = 'http://localhost:3000'; private socket;

constructor() { this.socket = io(this.url); }

public sendMessage(message) { this.socket.emit('message', message); }

public getMessages() { let observable = new Observable(observer => { this.socket.on('message', (data) => { observer.next(data); }); return () => { this.socket.disconnect(); }; }) return observable; } }

然后在组件中订阅服务器的通知,并在数据更改时触发刷新操作:

import { Component } from '@angular/core'; import { SocketService } from './socket.service';

@Component({ selector: 'app-root', template:

  • {{message}}
, styleUrls: ['./app.component.css'] }) export class AppComponent { messages = [];

constructor(private socketService: SocketService) { this.socketService.getMessages().subscribe(message => { this.messages.push(message); //trigger refresh of data }); } }

在服务器端(基于Node.js),可以使用socket.io来将连接的客户端订阅到某个数据库表的更改事件上,并在每次更改时向客户端发送通知:

var app = require('express')(); var http = require('http').createServer(app); var io = require('socket.io')(http); var pg = require('pg'); const { Pool, Client } = require('pg')

const pool = new Pool({ user: 'postgres', host: 'localhost', database: 'test',

相关内容

热门资讯

透视安装!菠萝辅助器免费版的功... 透视安装!菠萝辅助器免费版的功能介绍(透视)原来是有辅助神器(有挂解密)-哔哩哔哩运菠萝辅助器免费版...
透视教学!hhpoker德州牛... 透视教学!hhpoker德州牛仔视频(透视)竟然真的有辅助app(有挂透明挂)-哔哩哔哩1、进入到h...
昨日!hhpoker有后台操控... 昨日!hhpoker有后台操控吗(透视)好像真的有辅助修改器(有挂教程)-哔哩哔哩1、进入到hhpo...
透视新版!we-poker软件... 透视新版!we-poker软件(透视)确实是真的辅助安装(有挂解惑)-哔哩哔哩1、操作简单,无需we...
截至发稿!智星菠萝有挂吗(透视... 截至发稿!智星菠萝有挂吗(透视)切实是有辅助修改器(有挂解密)-哔哩哔哩在进入智星菠萝有挂吗软件靠谱...
长期以来!wepoker的辅助... 长期以来!wepoker的辅助器(透视)竟然是有辅助安装(有挂规律)-哔哩哔哩1、不需要AI权限,帮...
截至目前!hhpoker脚本(... 截至目前!hhpoker脚本(透视)切实真的是有辅助神器(了解有挂)-哔哩哔哩hhpoker脚本透视...
据统计!wepoker私人局开... 据统计!wepoker私人局开挂视频(透视)原来真的是有辅助插件(有人有挂)-哔哩哔哩1、wepok...
围绕透视问题!约局吧是否有挂(... 围绕透视问题!约局吧是否有挂(透视)原来真的有辅助修改器(有挂技巧)-哔哩哔哩1、约局吧是否有挂破解...
近期!德州透视脚本(透视)本来... 近期!德州透视脚本(透视)本来是真的辅助软件(有挂总结)-哔哩哔哩1、每一步都需要思考,不同水平的挑...