Heim > Web-Frontend > js-Tutorial > Hauptteil

Vue kombiniert SignalR-Front-End- und Front-End-Echtzeit-Nachrichtensynchronisierungsimplementierungsmethoden

小云云
Freigeben: 2018-02-05 16:15:42
Original
2743 Leute haben es durchsucht

In diesem Artikel wird hauptsächlich Vue in Kombination mit SignalR vorgestellt, um eine Echtzeit-Nachrichtensynchronisierung zu erreichen. Interessierte Freunde können darauf verweisen.

In letzter Zeit ist es im Geschäftsleben notwendig, die Echtzeitkommunikationsfunktion zwischen dem Server und dem Client zu realisieren, daher habe ich eine Zusammenfassung und Anordnung von Signalr erstellt.

SignalR kann als Bibliothek von ASP.NET einfach und bequem serverseitige und clientseitige Zwei-Wege-Kommunikationsfunktionen in Echtzeit für Anwendungen bereitstellen.

SignalR verfügt auf der Clientseite über zwei APIs: Verbindungen und Hubs.

In besonderen Fällen, beispielsweise wenn das Format der gesendeten Nachricht spezifisch und unverändert ist, verwenden Sie die Connections-API.

Hubs werden in den meisten Fällen verwendet, da es sich um eine fortgeschrittenere Implementierung der Connections-API handelt, die es dem Client und dem Server ermöglicht, Methoden direkt gegenseitig aufzurufen. Ein spezifisches Szenario für die praktische Anwendung: Wenn der Server beispielsweise eine neue Bestellung erhält, ruft er die Druckmethode des Clients auf. Nachdem der Client den Druckvorgang abgeschlossen hat, ruft er die Aktualisierungsmethode für den Bestellstatus des Servers auf.

Im Folgenden wird die API von Hubs am Frontend vorgestellt

generierter Proxy

Bei Verwendung eines generierten Proxys ist es einfacher, Dienste am anzurufen Syntaxebene Nebenmethode, genau wie der direkte Aufruf auf der Serverseite.

Das Folgende ist der Servercode, der das Hinzufügen einer Chat-Nachricht zur Liste bedeutet


public class DemoChatHub : Hub
{
  public void NewChatMessage(string name, string message)
  {
    Clients.All.addMessageToList(name, message);
  }
}
Nach dem Login kopieren

Beim Aufruf durch den Client:


var demoChatHubProxy = $.connection.DemoChatHub;
demoChatHubProxy.client.addMessageToList = function (name, message) {
  console.log(name + ' ' + message);
};
$.connection.hub.start().done(function () {
 
  $('#newChatMessage').click(function () {
     demoChatHubProxy.server.newChatMessage($('#displayname').val(), $('#message').val());
   });
});
Nach dem Login kopieren

Wenn der generierte Proxy nicht verwendet wird und der Client ihn aufruft, ist er


var connection = $.hubConnection();
var demoChatHubProxy = connection.createHubProxy('demoChatHub');
demoChatHubProxy.on('addMessageToList', function(name, message) {
  console.log(name + ' ' + message);
});
connection.start().done(function() {
  $('#newChatMessage').click(function () {
    demoChatHubProxy.invoke('newChatMessage', $('#displayname').val(), $('#message').val());
    });
});
Nach dem Login kopieren

Aber in Das Vue-Projekt. Wenn das Front- und Back-End getrennt sind, werden sie nicht wie folgt referenziert:


<script src="@Url.Content("~/signalr/hubs")" type="text/javascript"></script>
Nach dem Login kopieren

Und wenn Sie mehrere Event-Handler im verwenden möchten Bei der Client-Methode können Sie keinen generierten Proxy verwenden.

Daher verwenden die folgenden Beispiele keinen generierten Proxy.

1. So stellen Sie eine Verbindung her


var connection = $.hubConnection(&#39;localhost:23123&#39;);//如果前后端为同一个端口,可不填参数。如果前后端分离,这里参数为服务器端的URL
var demoChatHubProxy = connection.createHubProxy(&#39;demoChatHub&#39;);
demoChatHubProxy.on(&#39;addMessageToList&#39;, function(userName, message) {
  console.log(userName + &#39; &#39; + message);
}); 
connection.start()
  .done(function(){ console.log(&#39;Now connected, connection ID=&#39; + connection.id); })
  .fail(function(){ console.log(&#39;Could not connect&#39;); });
Nach dem Login kopieren

Vor dem Verbindungsaufbau ist zu beachten ( Rufen Sie vorher die Startmethode auf. Es ist am besten, mindestens eine Ereignisbehandlungsmethode zu registrieren. Wenn sie nicht registriert ist, wird die OnConnected-Methode von Hubs nicht aufgerufen, und die Methode des Clients kann nicht vom Server aufgerufen werden (dies). es ist leicht, in Schwierigkeiten zu geraten, also registrieren Sie sich im Voraus.

2. Wie der Client die serverseitige Methode aufruft
Beachten Sie, dass der erste Buchstabe des Methodennamens beim Aufrufen des Servers nicht erforderlich ist Wenn der Methodenname eingeschränkt ist, muss er in der Backend-Konfiguration großgeschrieben werden.


demoChatHubProxy.invoke(&#39;newChatMessage&#39;, {name:&#39;a&#39;,message:&#39;b&#39;});
Nach dem Login kopieren

3. Der Server ruft die Client-Methode auf

Zuerst muss der Client die Methode registrieren Der Server kann am Ende aufgerufen werden und die On-Methode zum Registrieren verwenden.


demoChatHubProxy.on(&#39;addMessageToList&#39;, function(userName, message) {
  console.log(userName + &#39; &#39; + message);
});
Nach dem Login kopieren

4 Verwenden von SignalR in einem Vue-Projekt

Installieren Sie zuerst das SignalR-Paket. Bitte beachten Sie, dass SignalR basiert auf jQuery.

npm i signalr,jquery

Der Einfachheit halber registrieren Sie globale jQuery in webpack.base.conf.js


plugins: [new webpack.ProvidePlugin({
      $: &#39;jquery&#39;,
      jQuery: &#39;jquery&#39;,
      &#39;window.jQuery&#39;: &#39;jquery&#39;,
      &#39;root.jQuery&#39;: &#39;jquery&#39;
    })
  ]
Nach dem Login kopieren

Dann führen Sie SignalR in main.js ein

import 'signalr'

Zu diesem Zeitpunkt können Sie es dem hinzufügen Das Vue-Projekt SignalR wird verwendet und die entsprechende Konfiguration des Backends wird vorübergehend übersprungen.

Erstellen Sie eine neue signalr.js


import { Message } from &#39;element-ui&#39;;
const HUBNAME = &#39;DefaultHub&#39;;

/*客户端调用服务器端方法*/
//更新订单打印次数
const updateOrderPrint = {
  name:&#39;updateOrderPrint&#39;,
  method:function(data){
    console.log(data)
  }
}

/*服务器调用客户端方法*/
// 打印新订单
const printNewOrder = {
  name:&#39;printNewOrder&#39;,
  method:function(data){
    console.log(data)
  }
}
const get = {
  name:&#39;Get&#39;,
  method:function(data){
    console.log(data)
  }
}

//服务器端的方法
const serverMethodSets = [updateOrderPrint];
//客户端的方法
const clientMethodSets = [printNewOrder,get]; //将需要注册的方法放进集合

// 建立连接
export function startConnection() {
  let hub = $.hubConnection(process.env.HUB_API)
  let proxy = createHubProxy(hub) //需要先注册方法再连接
  hub.start().done((connection) =>{
    console.log(&#39;Now connected, connection ID=&#39; + connection.id)
  }).fail(()=>{
    Message(&#39;连接失败&#39; + error);
    console.log(&#39;Could not connect&#39;);
  })
  hub.error(function (error) {
    Message(&#39;SignalR error: &#39; + error);
    console.log(&#39;SignalR error: &#39; + error)
  })
  hub.connectionSlow(function () {
    console.log(&#39;We are currently experiencing difficulties with the connection.&#39;)
  });
  hub.disconnected(function () {
    console.log(&#39;disconnected&#39;)
  });
  return proxy
}
// 手动创建proxy
export function createHubProxy(hub){
  let proxy = hub.createHubProxy(HUBNAME)
  // 注册客户端方法
  clientMethodSets.map((item)=>{
    proxy.on(item.name,item.method)
  })
  return proxy
}
Nach dem Login kopieren

Auf diese Weise rufen Sie nach der Einführung von signalr.js in die Komponente die startConnection-Methode auf, um eine einzurichten Verbindung.

Verwandte Empfehlungen:

Python implementiert WeChat-Gruppennachrichten-Synchronisierungsroboter basierend auf itchat

Das obige ist der detaillierte Inhalt vonVue kombiniert SignalR-Front-End- und Front-End-Echtzeit-Nachrichtensynchronisierungsimplementierungsmethoden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage