微信小程序使用Socket - 新聞資(zī)訊 - 雲南小程序開發|雲南軟件開發|雲南網站(zhàn)建設-西山區知普網絡科技工作室

159-8711-8523

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

知識

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

微信小程序使用Socket

發表時間:2021-4-30

發布人:葵宇科技

浏覽次數:45

首先,一個(gè)小程序同時隻能有一個(gè)WebSocket連接,如(rú)果當前已經存在一個(gè)WebSocket連接,會關(guān)閉當前連接,并重新建立一個(gè)連接。

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

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

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

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

2、然後 npm install wxapp-socket-io

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

  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、在要引用的頁面調用,全局封裝訂閱方法

  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. });

相關(guān)案例查看更多