<template>
<view style="flex: 1;">
<view class="uni-padding-wrap uni-common-mt">
<view class="uni-common-mt" style="border-width: 2px;border-style: solid; border-radius: 4px;">
<textarea :value="res" class="uni-textarea" style="width: 100%"></textarea>
</view>
<view>
<text>地址 : {{ host + url}}</text>
<text>请求方式 : {{method}}</text>
</view>
<view class="uni-btn-v uni-common-mt">
<button type="primary" @tap="checkRequestTask" id="checkRequestTask">发起流式请求(设置监听需重新点击、勿重复点击)</button>
<view class="uni-common-pb"></view>
<button type="primary" @tap="abort" id="abort">中断流式请求</button>
</view>
</view>
<scroll-view style="flex: 1;" show-scrollbar="true">
<view style="padding: 20px;">
<text>添加或者移除流式监听</text>
<view class="uni-common-pb"></view>
<view style="flex-direction: row;flex-wrap: wrap;">
<button style="padding: 5px;" type="primary" size="mini" @tap="onHeadersReceived_observe_1"
id="onHeadersReceived_observe_1">onHeadersReceived监听1</button>
<button style="padding: 5px;" type="primary" size="mini" @tap="onHeadersReceived_observe_2"
id="onHeadersReceived_observe_2">onHeadersReceived监听2</button>
<button style="padding: 5px;" type="primary" size="mini" @tap="onChunkReceived_observe_1"
id="onChunkReceived_observe_1">onChunkReceived监听1</button>
<button style="padding: 5px;" type="primary" size="mini" @tap="onChunkReceived_observe_2"
id="onChunkReceived_observe_2">onChunkReceived监听2</button>
<button style="padding: 5px;" type="primary" size="mini" @tap="offHeadersReceived_id"
id="offHeadersReceived_id">offHeadersReceived(id)</button>
<button style="padding: 5px;" type="primary" size="mini" @tap="offHeadersReceived_observe"
id="offHeadersReceived_observe">offHeadersReceived移除所有</button>
<button style="padding: 5px;" type="primary" size="mini" @tap="offChunkReceived_observe"
id="offChunkReceived_observe">offChunkReceived移除所有</button>
</view>
</view>
</scroll-view>
</view>
</template>
<script setup lang="uts">
const res = ref('')
const task = ref<RequestTask | null>(null)
const host = "https://request.dcloud.net.cn"
const url = "/api/http/contentType/eventStream?limit=10"
const method: RequestMethod = "POST"
const onHeadersReceivedObseves = ref<number[]>([])
const onChunkReceivedObseves = ref<number[]>([])
const onHeadersReceived_returnid_1 = ref(-1)
const onHeadersReceived_returnid_2 = ref(-1)
const isAbort = ref(false)
onLoad((options : OnLoadOptions) => {
onHeadersReceivedObseves.value.push(1)
onChunkReceivedObseves.value.push(1)
})
onUnload(() => {
uni.hideLoading();
task.value?.abort();
})
function onHeadersReceived_observe_1() {
onHeadersReceivedObseves.value.push(1)
}
function onHeadersReceived_observe_2() {
onHeadersReceivedObseves.value.push(2)
}
function offHeadersReceived_observe() {
onHeadersReceivedObseves.value = []
}
function offHeadersReceived_id() {
onHeadersReceivedObseves.value = []
onHeadersReceivedObseves.value.push(1)
}
function onChunkReceived_observe_1() {
onChunkReceivedObseves.value.push(1)
}
function onChunkReceived_observe_2() {
onChunkReceivedObseves.value.push(2)
}
function offChunkReceived_observe() {
onChunkReceivedObseves.value = []
}
function checkRequestTask() {
isAbort.value = false
res.value = '发起post流式请求 \n\n'
task.value = uni.request({
url: "https://request.dcloud.net.cn/api/http/contentType/eventStream?limit=10",
timeout: 600000,
method: method,
enableChunked: true,
success: (response) => {
console.log('request success', JSON.stringify(response.data))
console.log('request success header is :', JSON.stringify(response.header))
res.value += '流式请求结束 \n\n'
console.log('请求结果 : ' + JSON.stringify(response))
},
fail: (err) => {
let content = err.errMsg
if (isAbort.value) {
content = "中断成功"
}
console.log('request fail', err);
uni.showModal({
content: content,
showCancel: false
});
},
complete: () => {
task.value = null
},
});
const onHeadersReceivedCallback1 = (response : RequestTaskOnHeadersReceivedListenerResult) => {
console.log("-------onHeadersReceived监听1------", response)
res.value += `onHeadersReceived监听1:\n ${JSON.stringify(response)} \n\n`
}
const onHeadersReceivedCallback2 = (response : RequestTaskOnHeadersReceivedListenerResult) => {
console.log("-------onHeadersReceived监听2------", response)
res.value += `onHeadersReceived监听2:\n ${JSON.stringify(response)} \n\n`
}
if (onHeadersReceivedObseves.value.includes(1)) {
onHeadersReceived_returnid_1.value = task.value?.onHeadersReceived(onHeadersReceivedCallback1) ?? -1
}
if (onHeadersReceivedObseves.value.length == 0) {
task.value?.offHeadersReceived(null)
res.value += "点击了 offHeadersReceived \n\n"
} else if (onHeadersReceivedObseves.value.length == 1) {
task.value?.offHeadersReceived(onHeadersReceived_returnid_2.value)
}
const onChunkReceivedCallback1 = (response : RequestTaskOnChunkReceivedListenerResult) => {
const chunkText : string = new TextDecoder().decode(response.data)
console.log("-------onChunkReceived监听1------", chunkText)
res.value += `onChunkReceived监听1:\n ${chunkText}`
}
const onChunkReceivedCallback2 = (response : RequestTaskOnChunkReceivedListenerResult) => {
const chunkText : string = new TextDecoder().decode(response.data)
console.log("-------onChunkReceived监听2------", chunkText)
res.value += `onChunkReceived监听2:\n ${chunkText}`
}
if (onHeadersReceivedObseves.value.includes(2)) {
onHeadersReceived_returnid_2.value = task.value?.onHeadersReceived(onHeadersReceivedCallback2) ?? -1
}
if (onChunkReceivedObseves.value.includes(1)) {
task.value?.onChunkReceived(onChunkReceivedCallback1)
}
if (onChunkReceivedObseves.value.includes(2)) {
task.value?.onChunkReceived(onChunkReceivedCallback2)
}
if (onChunkReceivedObseves.value.length == 0) {
task.value?.offChunkReceived(null)
res.value += "点击了 offChunkReceived \n\n"
}
}
function abort() {
isAbort.value = true
task.value?.abort()
}
</script>
<style>
.uni-textarea {
padding: 9px;
font-size: 14px;
}
</style>