商城系統(tǒng) 注冊(cè)

微信小程序使用Socket注意事項(xiàng)及實(shí)例

2020-09-27|HiShop
導(dǎo)讀:一個(gè)小程序 同時(shí)只能有一個(gè)WebSocket連接,如果當(dāng)前已經(jīng)存在一個(gè)WebSocket連接,會(huì)關(guān)閉當(dāng)前連接,并重新建立一個(gè)連接。...

首先,一個(gè)小程序同時(shí)只能有一個(gè)WebSocket連接,如果當(dāng)前已經(jīng)存在一個(gè)WebSocket連接,會(huì)關(guān)閉當(dāng)前連接,并重新建立一個(gè)連接。

其次,如果使用了appID,協(xié)議必須是 wss://...

最近團(tuán)隊(duì)用小程序做行情,在連接socket的時(shí)候,發(fā)現(xiàn)在還沒(méi)有進(jìn)行subscribe的情況下,就直接進(jìn)行了廣播,并且自動(dòng)關(guān)閉了socket連接,

時(shí)間緊迫,抓耳撓腮,遂引用了socket-io(基于小程序的websocket仿寫(xiě)的socket-io,并非官方的socket-io,傳送門(mén)),使用方法:

微信小程序使用Socket注意事項(xiàng)及實(shí)例

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

2、然后 npm install wxapp-socket-io

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

 

  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、在要引用的頁(yè)面調(diào)用,全局封裝訂閱方法

 

  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調(diào)用
  11. openSocket.connect(function (status, ws) {
  12. if (status) {
  13. socket = ws
  14. this.subscribe('zl')//對(duì)封裝好對(duì)訂閱方法進(jìn)行調(diào)用
  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 = {//僅供參考,根據(jù)接口自行更改
  29. eis: eis.join(',')
  30. }
  31. socket.emit('subscribe', JSON.stringify(param));
  32. }
  33. }
  34. }
  35. });

電話咨詢(xún) 預(yù)約演示 0元開(kāi)店