dodu2014 / SignalRMiniProgram-Client

signalr core 与小程序交互

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

参考博文地址 https://www.cnblogs.com/LiangSW/p/9415246.html

SignalRMiniProgram参考地址 传送门:https://github.com/liangshiw/SignalRMiniProgram-Client

SignalR官方学习教程地址 https://docs.microsoft.com/zh-cn/aspnet/core/signalr/introduction?view=aspnetcore-2.2

核心思路

SignalRMiniSignalR.js帮助类库:使用微信小程序webSocket的api与后台建立socket连接,后端使用signalR组件建立hub(中心),通过hub(中心)发送信息到客户端或者接受来自于客户端的信息,传递信息大都包括要调用的函数名称,函数参数等关键信息,如果匹配到相同的名称的函数名,则执行相关的操作; SignalRMiniSignalR.js中使用数组存储可能被后端调用的方法名和方法体,如果匹配到相关的函数,就执行操作;

SignalRMiniProgram

AspNet Core SignalR 微信小程序客户端

效果演示

### Get Started

创建对象

let hub  = new HubConnection();

开启连接

hub.start(url,queryString);
例如
hub.start(url,{
    access_token:"bearer token"
});

事件

//连接开启事件
hub.onOpen = (res)={
    console.log("连接已开启")
};

//连接关闭事件
hub.onClose = (res)={
    console.log("连接已关闭")
};

//通讯过程中的Error事件
hub.onError = (res) =>{
    console.log(res)
};

//手动关闭连接
hub.close({reason:"手动关闭"});

调用服务端方法(无返回值)

hub.send(methodName,agrs...);

调用服务端方法(有返回值)

//该方法会返回一个Promise
hub.invoke(methodName,agrs...).then((res)=>{
    console.log("返回值:"+ res);
});

注册客户端方法供服务端调用

//该方法会返回一个Promise
hub.on("clientMethod",(res)=>{
    console.log("被服务端调用");
})

About

signalr core 与小程序交互


Languages

Language:JavaScript 100.0%