• 【前端异常】JavaScript错误处理:分析 Uncaught(in promise) error


    在开发过程中,JavaScript的错误处理是一个老生常谈的话题。当应用程序发生未捕获的异常时,Uncaught(in promise) error是其中最常见的错误类型。这篇文章将从多个方面详细阐述这种错误类型的原因与解决方案。

    一、Promise是什么

    Promise是一种用于异步编程的原生JavaScript对象。它提供了一种处理异步操作结果的方式,Promise表示一个异步任务的延迟状态。

    new Promise((resolve, reject) => {
      // 异步操作
      if (success) {
        resolve(result);
      } else {
        reject(error);
      }
    }).then((result) => {
      // 处理异步操作结果(成功后的)
    }).catch((error) => {
      // 处理异步操作错误(有异常的)
    });
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    Promise构造函数接收一个执行函数作为参数,并在异步操作完成后调用resolve或reject方法。

    然后,我们可以使用then和catch方法处理相应的结果或错误。如果Promise的状态变为resolved,then方法被调用。否则,如果状态变为rejected,catch方法被调用。

    下面是我项目中 index.js 中使用的方式:

    export function addAlarmRule(data) {
    	return request({
    		url: '/device/rule',
    		method: 'post',
    		data: data
    	});
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    index.vue 代码中使用的方式如下:

    /** 提交按钮 */
    submitForm: function() {
    	this.$refs['form'].validate(valid => {
    		if(valid) {
    			if(this.form.ruleId !== undefined) {
    				updateAlarmRule(this.form).then(response => {
    					this.$modal.msgSuccess('修改成功');
    					this.open = false;
    					this.reload();
    				});
    			}else {
    				addAlarmRule(this.form).then(response => {
    					this.$modal.msgSuccess('新增成功');
    					this.open = false;
    					this.reload();
    				});
    			}
    		}
    	});
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    注意:上述代码中,没有使用catch方法处理异常。

    二、什么是 Uncaught(in promise) error

    Uncaught(in promise) error 表示一个Promise被rejected且未处理。

    const promise = new Promise((resolve, reject) => {
      reject('error');
    });
    
    • 1
    • 2
    • 3

    在上面示例中,创建了一个Promise并使用reject方法将其状态设置为rejected。但是,没有在后续代码中处理这个错误,此时就会导致 Uncaught(in promise) error。

    在这里插入图片描述

    三、解决方案

    3.1 使用catch方法处理Promise的错误

    在Promise中,catch方法被用来处理错误。如果Promise变成了rejected状态,那么catch方法会被调用。

    const promise = new Promise((resolve, reject) => {
      reject('error');
    }).catch((error) => {
      console.log(error);
    });
    
    • 1
    • 2
    • 3
    • 4
    • 5

    在上面示例中,代码添加了catch方法来捕获Promise的错误。如果Promise的状态变成rejected,那么catch方法会被调用,我们就可以在里面处理这个错误。

    我项目中的解决方式如下:

    index.js代码

    export async function addAlarmRule(data) {
    	const res = await request({
    		url: '/device/rule',
    		method: 'post',
    		data: data
    	});
    	if(res.code === 200) {
    		return res.data;
    	}
    	return Promise.reject(new Error(res.message));
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    index.vue代码

    /** 提交按钮 */
    submitForm: function() {
    	this.$refs['form'].validate(valid => {
    		if(valid) {
    			if(this.form.ruleId !== undefined) {
    				updateAlarmRule(this.form).then(response => {
    					this.$modal.msgSuccess('修改成功');
    					this.open = false;
    					this.reload();
    				}).catch((e) => {
    					this.$message.error(e.message);
    				});
    			}else {
    				addAlarmRule(this.form).then(response => {
    					this.$modal.msgSuccess('新增成功');
    					this.open = false;
    					this.reload();
    				}).catch((e) => {
    					this.$message.error(e.message);
    				});
    			}
    		}
    	});
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24

    3.2 使用 async/await 处理Promise的错误

    如果代码上不方便使用catch方法或者不能使用catch方法处理Promise的错误,我们可以使用async/await语法糖来捕获Promise的错误。

    async function asyncFunction() {
      try {
        const promise = new Promise((resolve, reject) => {
          reject('error');
        });
        const result = await promise;
      } catch (error) {
        console.log(error);
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    在上述示例中,将Promise的代码放在一个async函数中,并使用await关键字等待Promise对象。如果Promise变成了rejected状态,try/catch将会捕获这个错误并进行处理。

    3.3 全局异常处理

    使用window.addEventListener(‘unhandledrejection’, callback)处理所有未处理错误
    如果应用程序中有很多Promise,我们可以使用window.addEventListener(‘unhandledrejection’, callback)来处理所有未处理错误。

    window.addEventListener('unhandledrejection', (event) => {
      console.log(event.reason);
    });
    
    • 1
    • 2
    • 3

    四、结论

    当我们使用Promise进行异步编程时,Uncaught(in promise) error 是一个常见的错误类型。这种错误类型通常是由于没有处理Promise的错误而导致的。在多数情况下,我们可以使用catch方法或者async/await语法糖来解决这种错误类型。如果应用程序中有很多Promise,我们可以使用window.addEventListener(‘unhandledrejection’, callback)来处理所有未处理的错误。根据代码情况可以使用不同的处理方法。

    本文完结!

  • 相关阅读:
    cannot allocate memory in static TLS block
    1.3.19 网络端口地址转换 NAPT 配置
    ip地址会随网络变化而变化吗
    项目实战:修改水果库存系统特定库存记录
    大数据从入门到精通(超详细版)之HiveServer2的使用
    四种强大且隐秘的缓存
    从零开始运行YOLOV5
    秋招每日一题T3——设计循环双端队列
    Windows系统设置mysql主从模式
    IATF16949认证审核要点
  • 原文地址:https://blog.csdn.net/weixin_44299027/article/details/134382584