9.9-9.13 异步调用函数出错(比如未定义该函数),会造成阻塞。可能页面不会打印错误信息

本文探讨了在device.js中不规范的Promise错误处理机制,提出了使用Promise.all避免阻塞的方法,并讨论了异步函数错误捕获、视音频XML保存格式问题及设备协议排查技巧。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

迁移4.2门口机基线

1.目前device.js里的能力集方法,await下错误处理机制都是resolve(),事实上是不规范的。据说是为了避免阻塞

return new Promise(resolve => {
            return _oWebSdk.WSDK_GetDeviceConfig("analysisUnitSwitch", {
                channel: iChannelId
            }, {
                success: (xmlDoc) => {
                    this.m_oDeviceCapa.bEnableLocalDetection = $(xmlDoc).find("switch").eq(0).text() === "local";
                    resolve();
                },
                error: () => {
                    this.m_oDeviceCapa.bEnableLocalDetection = false;
                    resolve();
                }
            });
        });

实际上使用Promise.all直接也可以避免阻塞

2.异步调用函数出错(比如未定义该函数),会造成阻塞。可能页面不会打印错误信息,这时候使用try...catch,可以打印错误信息

3.视音频-视频 保存XML格式不对,很难排查,暂时略过

4.当有的设备正常,另一个设备不正常,考虑排查发回的协议。当我们这边调试的协议直接进入错误回调,考虑传回的XML格式无法解析造成的问题。IE和chrome都会出现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值