微信小程序使用Socket - 新聞資訊 - 雲南小程序開發|雲南軟件開發|雲南網站建設-昆明融晨信息技術有限公司

159-8711-8523

雲南網建設/小程序開發/軟件開發

知識

不(bù)管是(shì)網站,軟件還是(shì)小程序,都要(yào / yāo)直接或間接能爲(wéi / wèi)您産生價值,我們在(zài)追求其視覺表現的(de)同時(shí),更側重于(yú)功能的(de)便捷,營銷的(de)便利,運營的(de)高效,讓網站成爲(wéi / wèi)營銷工具,讓軟件能切實提升企業内部管理水平和(hé / huò)效率。優秀的(de)程序爲(wéi / wèi)後期升級提供便捷的(de)支持!

您當前位置>首頁 » 新聞資訊 » 小程序相關 >

微信小程序使用Socket

發表時(shí)間:2021-4-30

發布人(rén):融晨科技

浏覽次數:66

首先,一個(gè)小程序同時(shí)隻能有一個(gè)WebSocket連接,如果當前已經存在(zài)一個(gè)WebSocket連接,會關閉當前連接,并重新建立一個(gè)連接。

其次,如果使用了(le/liǎo)appID,協議必須是(shì) wss://...

最近團隊用小程序做行情,在(zài)連接socket的(de)時(shí)候,發現在(zài)還沒有進行subscribe的(de)情況下,就(jiù)直接進行了(le/liǎo)廣播,并且自動關閉了(le/liǎo)socket連接,

時(shí)間緊迫,抓耳撓腮,遂引用了(le/liǎo)socket-io(基于(yú)小程序的(de)websocket仿寫的(de)socket-io,并非官方的(de)socket-io,傳送門),使用方法:

1、先在(zài)utils文件夾粘貼一個(gè)io的(de)js

2、然後 npm install wxapp-socket-io

3、config文件夾下新建一個(gè)socket.js,對socket連接進行封裝,如下:

  1. const io = require('../utils/io.js')
  2. let url = 'wss://......'
  3. let wsStatus = false
  4. let onSocket = null
  5. export const connect = function(cb){
  6. if(!onSocket){
  7. onSocket = io(url)
  8. onSocket.on('connect', function (res) {
  9. cb(true,onSocket)
  10. wsStatus = true
  11. })
  12. setTimeout(function(){
  13. if(!wsStatus){
  14. cb(false,onSocket)
  15. }
  16. },10000)
  17. }else{
  18. cb(true,onSocket)
  19. }
  20. }

4、在(zài)要(yào / yāo)引用的(de)頁面調用,全局封裝訂閱方法

  1. let openSocket = require('../../config/socket')
  2. let app = getApp()
  3. let socket = null
  4. Page({
  5. data: {
  6. zl: [[422, 400, 468, 834, 785, 446, 845, 517, 630, 797, 890, 529, 553, 425, 469, 470, 837, 841, 521, 525], [422, 400, 468, 834, 785, 446, 845, 517, 630, 797, 890, 529, 553, 425, 469, 470, 837, 841, 521, 525]]
  7. },
  8. onLoad: function () {
  9. let that = this;
  10. //socket調用
  11. openSocket.connect(function (status, ws) {
  12. if (status) {
  13. socket = ws
  14. this.subscribe('zl')//對封裝好對訂閱方法進行調用
  15. socket.on('broadcast', function (msg) {//廣播
  16. console.log("broadcast");
  17. console.log(msg);
  18. })
  19. } else {
  20. alert("socket 連接失敗")
  21. }
  22. });
  23. },
  24. subscribe: function (type) {
  25. if (socket) {
  26. let eis = this.data[type]
  27. if (eis && eis.length > 0) {
  28. let param = {//僅供參考,根據接口自行更改
  29. eis: eis.join(',')
  30. }
  31. socket.emit('subscribe', JSON.stringify(param));
  32. }
  33. }
  34. }
  35. });

相關案例查看更多