当我们使用微信小程序对接ai功能时一般都需要打字机效果,一般ai接口都是sse协议,但是微信小程序不支持,垃圾东西,阉割了h5标准功能。我们需要给微信小程序模拟支持下。代码如下:
类库如下:
class EventSource { constructor(url, retryTime = 0) { this.url = url; this.retryTime = retryTime; this.listeners = {}; this.requestTask = null this.connect() } connect() { this.requestTask = wx.request({ url: this.url, enableChunked: true, responseType: 'text', method: 'GET', timeout: 300e3, success: res => { this.emit('success', res) if (this.retryTime > 0) { setTimeout(() => { this.connect() }, this.retryTime) } }, fail: () => { } }); this.requestTask.onHeadersReceived(res => { this.emit('open', res); }) this.requestTask.onChunkReceived(res => this.handleChunk(res)) } handleChunk(res) { console.log('ok'); const arrayBuffer = res.data; const uint8Array = new Uint8Array(arrayBuffer); let data = uni.arrayBufferToBase64(uint8Array) data = new Buffer(data, 'base64') data = data.toString('utf8') const lines = data.split("\n\n") lines.forEach(line => { if (!line.trim()) { return } const [key, value] = line.trim().split(':'); if (key === 'data') { const data = line.substring(5).trim(); try { const json = JSON.parse(data); this.emit('message', { data: json }) } catch (e) { this.emit('error', 'Api.EventSource.ParseError:' + e) } } else { this.emit('error', 'Api.EventSource.ParseFail:' + line) } }) } addEventListener(event, callback) { if (!this.listeners[event]) { this.listeners[event] = [] } this.listeners[event].push(callback) } emit(event, data) { if (this.listeners[event]) { this.listeners[event].forEach(callback => { callback(data) }); } } close() { if (this.requestTask) { this.requestTask.abort() } } } module.exports = EventSource;
调用方式参考例子:
const es = new EventSource('http://api.20230611.cn/api/question/aiExplanation?id=' + item.id) es.addEventListener('open', res => { that.showAiExplanation = status; }); es.addEventListener('message', (event) => { console.log('message'); });
虽然支持了微信小程序,但是uniapp是基于webview实现,webview中不支持EventSource,太折腾了所以放弃了sse作为多平台协议的支持,还是websocket支持比较多。
捕捉模式从DOM最顶层一直到最后一层,冒泡正好相反,具体运行以下实例测试.<!DOCTYPE html> <html> <head> <title>捕捉和冒泡</title> <meta charset="...
TmodJS是一套完整的前端模块框架。 虽然我们PHP框架自带各种模板引擎,但是始终是后端模板引擎。例如我们在使用ThinkPHP3.2.3中如果是Ajax异步加载页面,拼接HTML真的是很头疼的一件事情。...
https://3gimg.qq.com/lightmap/v1/marker/index.html?marker=coord:37.6767600000,112.7297800000&key=TKUBZ-D24AF-GJ4JY-JDVM2-IBYKK-KEBCU&referer=p...
开发需求如下,商品下单后需要指定送到日期:送达日期为周一 周三 周六 ,如果今天周一,用户选择周一即为下一周周一。代码如下:<html> <head> <meta charset="utf-8"> <title>...
代码1:<!--代码开始--> <script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script> <script>...
二期项目中生成的简历二维码是使用canvs生成的,微信浏览器中不能识别二维码,只能扫码。懒的换phpqrcode,于是转canvs。//设置一个url var url = "{yun:}$config.sy_weburl{/yun}/mingli/index....