国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

angular中使用Socket.io實例代碼

2019-11-19 16:25:51
字體:
來源:轉載
供稿:網友

服務端(nodeJs/express):

let app = require('express')();let http = require('http').Server(app);let io = require('socket.io')(http);io.on('connection', (socket) => { console.log('user connected');  socket.on('disconnect', function(){  console.log('user disconnected'); });  socket.on('add-message', (message) => {  io.emit('message', {type:'new-message', text: message});   });});http.listen(5000, () => { console.log('started on port 5000');});

客戶端,創建一個ChatService

import { Subject } from 'rxjs/Subject';import { Observable } from 'rxjs/Observable';import * as io from 'socket.io-client';export class ChatService { private url = 'http://localhost:5000';  private socket;  sendMessage(message){  this.socket.emit('add-message', message);   }  getMessages() {  let observable = new Observable(observer => {   this.socket = io(this.url);   this.socket.on('message', (data) => {    observer.next(data);     });   return () => {    this.socket.disconnect();   };   })     return observable; } }

ChatComponent

import { Component, OnInit, OnDestroy } from '@angular/core';import { Control }      from '@angular/common';import { ChatService }    from './chat.service';@Component({ moduleId: module.id, selector: 'chat', template: `<div *ngFor="let message of messages">           {{message.text}}          </div>          <input [(ngModel)]="message" /><button (click)="sendMessage()">Send</button>`, providers: [ChatService]})export class ChatComponent implements OnInit, OnDestroy { messages = []; connection; message;  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(); }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 延寿县| 黔西| 澄迈县| 沙坪坝区| 开化县| 宜良县| 吉木萨尔县| 白山市| 行唐县| 蒙自县| 林州市| 青铜峡市| 吴川市| 桑日县| 马鞍山市| 沙雅县| 徐闻县| 海阳市| 陆丰市| 洛阳市| 浮梁县| 黄浦区| 六安市| 墨脱县| 桑植县| 巢湖市| 乐昌市| 沧州市| 阿坝县| 四平市| 白玉县| 陇川县| 临泉县| 松原市| 漾濞| 汉中市| 普安县| 黄石市| 桦川县| 都兰县| 岫岩|