数据传输优化-异步不阻塞处理增强首屏体验

背景:主 project 页面中会将视频存储到云端后获得 ID ,然后用 ID 调用 后端API POST到数据库后拿到挂载页面URL,接着传入视频分享组件(由于视频分享子组件的目标是分享视频挂载页面,所以前置步骤不能少)

javascript 复制代码
            const recordBlob = await projectRunnerRef.value?.stopRecording?.()
            await projectRunnerRef.value?.pauseGame()
            
            console.log('录制已停止,获得 Blob:', recordBlob)
            
            if (!recordBlob) {
                toaster.error('录制失败,未获得录制数据')
                isRecording.value = false
                return
            }
            
            // 将 Blob 转换为 File 对象
            const fileExtension = recordBlob.type?.includes('webm') ? 'webm' : 'mp4'
            const recordFile = new globalThis.File([recordBlob], `recording_${Date.now()}.${fileExtension}`, { 
                type: recordBlob.type || 'video/webm' 
            })

            recording.value = recordFile

            try {
                const projectFile = createProjectFile(recordFile)
                const RecordingURL = await saveFile(projectFile) // 存储到云端获得视频存储URL

遇到问题:通过查看网络通信发现传输到云端时间很长,所以页面上就像卡住了一样一直等待视频分享弹窗弹出

解决思路:惰性异步处理-不让阻塞其他执行。将原先先把所有必须的内容拿到再弹出弹框变成先加载弹窗,具体里面要用到视频挂载URL的地方其实就是生成二维码的地方,那么写成 'generating' 来优化交互体验,那么就需要将原先 props 传输 recording 变成一个 Promise 来异步处理

javascript 复制代码
const props = defineProps<{
    recording: Promise<RecordData>,

那么接收的是一个 Promise 而非直接的数据,从而允许异步加载,避免阻塞UI渲染,实现了数据与UI的解耦

那么从 project 父组件获得video(可选值,用于首屏展示),同时传入Promise实例用于并行处理

在云端 cloud.ts 中

javascript 复制代码
export async function saveFiles(
  files: Files,
  signal?: AbortSignal
): Promise<{ fileCollection: FileCollection; fileCollectionHash: string }> {
  const fileCollection = Object.fromEntries(
    await Promise.all(Object.keys(files).map(async (path) => [path, await saveFile(files[path]!, signal)] as const))
  )
  const fileCollectionHash = await hashFileCollection(fileCollection)
  return { fileCollection, fileCollectionHash }
}

通过 Promise.all 处理多文件上传

然后在 录屏组件中写一个副作用回调函数用于更新

javascript 复制代码
async function loadRecordingData() {
    if (currentRecording.value) return
    
    try {
        currentRecording.value = await props.recording
        await updateVideoSrc()
    } catch (error) {
        console.error('加载录制数据失败:', error)
    }
}

在 watch 中回调

javascript 复制代码
watch(() => props.visible, (newVisible) => {
    if (newVisible) {
        // 重置状态
        jumpUrl.value = ''
        qrCodeData.value = ''
        
        // 立即更新视频源(优先使用 props.video)
        updateVideoSrc()
        
        // 加载录制数据(用于分享参数)
        loadRecordingData()
相关推荐
奇舞精选3 小时前
超越Siri的耳朵:ASR与Whisper零代码部署实战指南
前端·人工智能·aigc
奇舞精选3 小时前
Nano Banana 如何为前端注入 AI 控制力
前端·aigc
一支鱼3 小时前
基于 Node.js 的短视频制作神器 ——FFCreator
前端·node.js·音视频开发
jingfeng5143 小时前
C++11可变参数模板、emplace系列接口、包装器
开发语言·c++
DT——3 小时前
前端登录鉴权详解
前端·javascript
云天徽上3 小时前
【数据可视化-107】2025年1-7月全国出口总额Top 10省市数据分析:用Python和Pyecharts打造炫酷可视化大屏
开发语言·python·信息可视化·数据挖掘·数据分析·pyecharts
Tina表姐4 小时前
(C题|NIPT 的时点选择与胎儿的异常判定)2025年高教杯全国大学生数学建模国赛解题思路|完整代码论文集合
c语言·开发语言·数学建模
李姆斯4 小时前
复盘上瘾症:到底什么时候该“复盘”,什么时候不需要“复盘”
前端·后端·团队管理
whysqwhw4 小时前
Kuikly 原生 API 扩展机制对比总结
前端