分享更有价值
被信任是一种快乐

JavaScript异常处理方式是什么

文章页正文上

这篇文章主要介绍“JavaScript异常处理方式是什么”,在日常操作中,相信很多人在JavaScript异常处理方式是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JavaScript异常处理方式是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!错误是编程过程的一部分。编写程序的过程难免会出现一些错误,通过这些产生的错误,我们可以学会如何避免遇到这样的情况,以及如何在下次做的更好。在 JavaScript 中,当代码语句紧密耦合并产生错误时,继续使用剩余的代码语句是没有意义的。相反,我们试图尽可能优雅地从错误中恢复过来。JavaScript 解释器在出现此类错误时检查异常处理代码,如果没有异常处理程序,程序将返回导致错误的任何函数。对调用堆栈上的每个函数重复此操作,直到找到异常处理程序或到达顶层函数,从而导致程序以错误终止,导致程序的崩溃。一般来说,有两种处理方式:抛出异常 — 如果在运行时发生的问题无法得到有意义的处理,最好抛出它捕获异常 — 抛出的异常在运行时更有意义的地方被捕获和处理让我们更详细地了解这些操作。您可能会看到类似 ReferenceError: specs is not defined 这样的情况。这表示通过 throw 语句引发的异常。语法对可以作为异常抛出的数据类型没有限制,但 JavaScript 具有特殊的内置异常类型。其中之一是 Error,正如您在前面的示例中所看到的。这些内置的异常类型为我们提供了比异常消息更多的细节。ErrorError 类型用于表示一般异常。这种类型的异常最常用于实现用户定义的异常。它有两个内置属性可供使用。message — 作为参数传递给 Error 构造函数的内容。例如,new Error(‘This is an error message’)。您可以通过 message 属性访问消息。stack — 该属性返回导致错误的文件的历史记录(调用堆栈)。堆栈顶部还包括 message,后面是实际堆栈,从最新/隔离的错误点开始,到最外部负责的文件。注意:new Error(‘…’) 在抛出之前不会执行任何操作,即 throw new Error(‘error msg’)  将在 JavaScript 中创建一个 Error 实例,并停止脚本的执行,除非您对 Error 错误执行某些操作,例如捕获它。现在我们知道了什么是异常以及如何抛出它们,让我们讨论一下如何通过捕获它们来阻止它们破坏我们的程序。try-catch-finally 是处理异常的最简单方法。在 try 子句中,我们添加了可能产生异常的代码。如果发生异常,则执行 catch 子句。有时,无论代码是否产生异常,都需要执行代码,这时我们可以使用可选块 finally。即使 try 或 catch 子句执行 return 语句,finally 块也将执行。例如,以下函数返回 ‘Execute finally’,因为 finally 子句是最后执行的内容。我们在无法事先检查代码正确性的地方使用 try-catch。如上所示,在执行代码之前,不可能检查 JSON.parse 以获得 stringify 对象或字符串。注意:您可以捕获程序产生的异常和运行时异常,但无法捕获 JavaScript 语法错误。try-catch-finally 只能捕获同步错误。如果我们尝试将其用于异步代码,那么在异步代码完成其执行之前,try-catch-finally 可能已经执行了。回调函数使用回调函数(不推荐),我们免费云主机、域名通常会收到两个如下所示的参数:我们可以看到有两个参数:err 和 result。如果有错误,err 参数将等于该错误,我们可以抛出该错误来进行异常处理。在 if (err) 块中返回某些内容或将其他指令包装在 else 块中都很重要。否则,您可能会遇到另一个错误。例如,当您尝试访问 result.data 时,result 可能未定义。Promises使用 promises 的 then 或者 catch,我们可以通过将错误处理程序传递给 then 方法或使用 catch 子句来处理错误。也可以使用 .catch(onRejected) 而不是 .then(null, onRejected) 添加错误处理程序,其工作方式相同。让我们看一个 .catch 拒绝 Promise 的例子。使用 async/await 和 try-catch使用 async/await 和 try-catch-finally,处理异常是轻而易举的事。现在我们已经很好地理解了如何在同步和异步代码块中执行异常处理,让我们回答本文最后一个待解决的问题 :我们如何处理未捕获的异常?在浏览器中我们可以使用 window.onerror() 方法来处理未捕获的异常。每当运行时发生错误时,该方法会在 window 对象上触发 error 事件。onerror() 的另一个实用做法是:当站点中的图片或视频等数据加载出错时,可以用该方法触发某些操作。例如,提供一张加载出错时的图片,或显示一条消息。在 Node.js 中EventEmitter 模块派生的 process 对象可以订阅事件 uncaughtException。我们可以传递一个回调来处理异常。如果我们尝试捕获这个未捕获的异常,进程将不会终止,因此我们必须手动完成。uncaughtException 仅适用于同步代码。对于异步代码,还有另一个称为 unhandledRejection 的事件。决不要尝试为基本 Error 类型实现 “捕获所有” 处理程序。这将混淆所发生的一切,并损害代码的可维护性和可扩展性。关键要点throw 语句用于生成用户定义的异常。在运行时,当 throw 遇到语句时,当前函数的执行将停止,控制权将传递给 catch 调用堆栈中的第一个子句。如果没有 catch 子句,程序将终止JavaScript 有一些内置的异常类型,最值得注意的是 Error,它返回 Error 中的两个重要属性:stack 和 message。try 子句将包含可能产生异常的代码,catch 子句会在发生异常时执行。对于异步代码,最好使用 async/await 配合 try-catch 语句。可以捕获未处理的异常,这可以防止应用程序崩溃。不要觉得麻烦,异常处理可以帮助您提高代码的可维护性、可扩展性和可读性。到此,关于“JavaScript异常处理方式是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注云技术网站,小编会继续努力为大家带来更多实用的文章!

相关推荐: jquery如何改变margin的值

这篇文章主要介绍“jquery如何改变margin的值”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“jquery如何改变margin的值”文章能帮助大家解决问题。 在jquery中,可以利用css()方法改变元素mar…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册