feat: web-socket

master
limin 2020-12-08 16:51:30 +08:00 committed by XuPeng
parent 4deb945d05
commit 6eeef4fee0
4 changed files with 141 additions and 0 deletions

View File

@ -0,0 +1,104 @@
// pages/API/web-socket/web-socket.js
function showModal(title, content) {
wx.showModal({
title,
content,
showCancel: false
})
}
function showSuccess(title) {
wx.showToast({
title,
icon: 'success',
duration: 1000
})
}
Page({
data: {
socketStatus: 'closed'
},
onLoad() {
const self = this
self.setData({
hasLogin: true
})
},
onUnload() {
this.closeSocket()
},
toggleSocket(e) {
const turnedOn = e.detail.value
if (turnedOn && this.data.socketStatus === 'closed') {
this.openSocket()
} else if (!turnedOn && this.data.socketStatus === 'connected') {
const showSuccess = true
this.closeSocket(showSuccess)
}
},
openSocket() {
// var socket = this.socket = new qcloud.Tunnel(tunnelUrl)
wx.onSocketOpen(() => {
console.log('WebSocket 已连接')
showSuccess('Socket已连接')
this.setData({
socketStatus: 'connected',
waitingResponse: false
})
})
wx.onSocketClose(() => {
console.log('WebSocket 已断开')
this.setData({socketStatus: 'closed'})
})
wx.onSocketError(error => {
showModal('发生错误', JSON.stringify(error))
console.error('socket error:', error)
this.setData({
loading: false
})
})
// 监听服务器推送消息
wx.onSocketMessage(message => {
showSuccess('收到信道消息')
console.log('socket message:', message)
this.setData({
loading: false
})
})
// 打开信道
wx.connectSocket({
url: 'wss://echo.websocket.org',
})
},
closeSocket() {
if (this.data.socketStatus === 'connected') {
wx.closeSocket({
success: () => {
showSuccess('Socket已断开')
this.setData({socketStatus: 'closed'})
}
})
}
},
sendMessage() {
if (this.data.socketStatus === 'connected') {
wx.sendSocketMessage({
data: 'Hello, Miniprogram!'
})
}
},
})

View File

@ -0,0 +1,3 @@
{
"navigationBarTitleText": "Web Socket"
}

View File

@ -0,0 +1,32 @@
<!--pages/API/web-socket/web-socket.wxml-->
<import src="../../common/head.wxml" />
<import src="../../common/foot.wxml" />
<view class="container">
<template is="head" data="{{title: 'WebSocket'}}"/>
<view class="page-body">
<view class="page-section">
<view class="weui-cells weui-cells_after-title">
<view class="weui-cell weui-cell_switch">
<view class="weui-cell__bd">Socket状态</view>
<view class="weui-cell__ft">
<switch bindchange="toggleSocket" disabled="{{!hasLogin}}"/>
</view>
</view>
<view class="weui-cell">
<view class="weui-cell__bd">消息</view>
<view class="weui-cell__ft">
Hello, 小程序!
</view>
</view>
</view>
</view>
<view class="btn-area">
<button type="primary" size="40" bindtap="sendMessage" disabled="{{socketStatus != 'connected'}}" loading="{{loading}}">点我发送</button>
</view>
</view>
<template is="foot" />
</view>

View File

@ -0,0 +1,2 @@
/* pages/API/web-socket/web-socket.wxss */
@import "../../common/lib/weui.wxss";