当前位置: 首页 > news >正文

哪里有做网站的平台企业架构设计

哪里有做网站的平台,企业架构设计,东莞市 住房与城乡建设部网站,网站建设的基本需求有哪些今天不睡,熬夜赶了个WebSocket 二次封装,也对这几天文章摸鱼感到抱歉,所以我出了一个注释非常非常全的代码 思路如下 首先,需要通过调用connect方法来建立WebSocket连接。当连接成功时,会调用我提供的回调函数,并将连接成功的消息帧作为参数…

今天不睡,熬夜赶了个WebSocket 二次封装,也对这几天文章摸鱼感到抱歉,所以我出了一个注释非常非常全的代码

思路如下
首先,需要通过调用connect方法来建立WebSocket连接。当连接成功时,会调用我提供的回调函数,并将连接成功的消息帧作为参数传递给它。在回调函数中,我们可以打印消息帧到控制台中。如果连接失败,则会执行catch回调函数,并打印错误信息到控制台中。

一旦连接成功,可以继续执行订阅主题的操作。通过调用subscribe方法,可以订阅一个特定的主题。当接收到消息时,会调用提供的回调函数,并将解析后的数据作为参数传递给它。在回调函数中,可以打印收到的数据到控制台中。如果订阅失败,则会执行catch回调函数,并打印错误信息到控制台中。

看在这么全的份上,请点个赞,不懂得可以问博主,看到会回

// 定义一个名为WebSocketClient的类  
class WebSocketClient {  // 构造函数,接收一个url作为参数,用于初始化WebSocketClient对象  constructor(url: string) {  // 将传入的url赋值给this.url,保存url的信息  this.url = url;  // 初始化socket属性为null,表示尚未建立WebSocket连接  this.socket = null;  // 初始化stompClient属性为null,表示尚未建立Stomp客户端连接  this.stompClient = null;  }  // 定义一个名为connect的方法,用于建立WebSocket连接并返回Promise对象  connect() {  // 返回一个新的Promise对象,Promise的参数是一个函数,该函数接收resolve和reject两个参数  return new Promise<void, Error>((resolve, reject) => {  try {  // 创建一个新的SockJS实例,使用this.url作为参数,尝试建立WebSocket连接  this.socket = new SockJS(this.url);  // 使用已建立的WebSocket连接创建一个Stomp客户端,stompClient属性保存这个客户端的引用  this.stompClient = Stomp.over(this.socket);  // 设置stompClient的debug属性为null,关闭日志输出    this.stompClient.debug = null; // 关闭日志      // 使用stompClient的connect方法进行连接,传入空回调函数和错误回调函数  this.stompClient.connect({}, (frame: { [key: string]: any }) => { // 当连接成功时,回调空回调函数,并将连接成功的消息帧传递给resolve参数  resolve(frame);  }, function (error) {  // 当连接失败时,回调错误回调函数,并将错误信息传递给reject参数  reject(error);  });  } catch (error) {  // 如果在尝试建立WebSocket连接或Stomp客户端的过程中抛出错误,将错误信息传递给reject参数  reject(error);  }  });  }  // 定义一个名为subscribe的方法,用于在已建立的连接上订阅主题并返回Promise对象  subscribe(topic: string) {  // 返回一个新的Promise对象,Promise的参数是一个函数,该函数接收resolve和reject两个参数  return new Promise<any, Error>((resolve, reject) => {  try {  // 使用已建立的stompClient和给定的主题进行订阅,传入一个回调函数和错误回调函数  this.stompClient.subscribe(topic, (data: any) => {  // 当接收到消息时,回调回调函数,并解析消息体为JSON格式的数据,然后打印到控制台中  var dataGm = JSON.parse(data.body);  console.log('数据', dataGm);  // 将解析后的数据传递给resolve参数,表示订阅成功完成  resolve(dataGm);  });  } catch (error) {  // 如果在尝试订阅主题的过程中抛出错误,将错误信息传递给reject参数  reject(error);  }  });  }  
}  

调用就像下面这样调用就好了

	// 使用示例:    let socketUrl: string = "http://192.168.1.38:8080/gs-guide-websocket";  let client: WebSocketClient = new WebSocketClient(socketUrl);  client.connect().then((frame: { [key: string]: any }) => {  console.log('连接成功', frame);  }).catch((error: Error) => {  console.error('连接失败', error);  });  client.subscribe('/topic').then((dataGm: any) => {  console.log('订阅成功', dataGm);  }).catch((error: Error) => {  console.error('订阅失败', error);  });
http://www.yayakq.cn/news/336894/

相关文章:

  • 网站建设top图网站开发技术指标
  • 安徽鑫华建设有限公司网站wordpress 做下载网
  • 大望路网站建设公司免费建网站在那里好
  • 阿里云服务器搭建网站网站建设文化服务
  • 网站策划和网站制作门户网站改造方案
  • 营销策划公司是干什么的广告优化师工资一般多少
  • 石材公司网站珠海网站制作网络公司
  • 盐城有没有做公司网站WordPress完整安裝包
  • 新公司做网站多少钱商家在携程旅游网站怎样做宣传
  • 宽带专家网站做电子商务网站的公司
  • 网站开发需要英语西宁设计网站建设
  • 网站引流.宝安中心医院口腔科电话
  • 昆明做网站找哪个公司好wordpress如何优化
  • 企业建设网站的方式wordpress作品展示模板
  • 私家网站ip地址大全js效果炫酷的网站推荐
  • 建跨境电商网站多少钱wordpress媒体库远程图片
  • 保健品网站建设策划书人才网官方网站
  • 网站建设论文二稿微投票网站
  • 套模板网站谷歌wordpress优化
  • 洛阳做网站推广新加坡网站后缀
  • 怎么看自己做没做网站地图wordpress 分页按钮 显示文章数
  • 网站超链接怎么做网站建设案例步骤
  • 在中国备案的网站服务器青岛网站建设与设计制作
  • godaddy上传网站有限公司 官网
  • 地情网站建设wordpress自动采集规则
  • 湖北省建设交易协会网站网赌网站做流量渗透
  • 昆明做商城网站多少钱装饰公司网站模板
  • 长沙制作网站设计多少钱一般通过微信号添加的微信好友
  • wap网站为什么没有了静态网站 源码
  • 广东网站建设968wordpress表单采集