JS异常处理——throw和try、catch以及debugger

让我为大家介绍一下异常处理吧!

异常处理是指预估代码执行过程中可能发生的错误,然后最大程度的避免错误的发生导致整个程序无法继续运行

throw 抛异常

第一种写法

javascript 复制代码
    function fun(x, y) {
        // undefined是false 但取反就是true
        if (!x || !y) {
            // 第一种写法 会终止程序
            throw "没有传递参数进来"
        }
        return x + y
    }
    fun()


第二种写法 常用的写法

javascript 复制代码
    function fun(x, y) {
        // undefined是false 但取反就是true
        if (!x || !y) {
            //第二种写法 会终止程序
            throw new Error("没有参数传递进来")
        }
        return x + y
    }
    fun()

会告诉你第几行有问题

总结:
1.throw 抛出异常信息,程序也会终止执行
2.throw 后面跟的是错误提示信息
3.Error 对象配合 throw 使用,能够设置更详细的错误信息

try / catch 捕获错误信息

我们可以通过 try / catch 捕获错误信息(浏览器提供的错误信息)

try 试试 catch 拦住 finally 最后

html 复制代码
<body>
    <div>111</div>
</body>
<script>
    function fun(){
        try {
            // 可能发生错误信息的代码写到try里
            // 我们使用类选择器去获取,但我们没定义类,展示作用
            let div = document.querySelector(".div")
            div.style.color = "pink"
        }catch(err){ //写一个形参
            // 拦截错误,提示浏览器提供的错误信息,但是不中断程序的执行
            console.log(err.message) //查看提示信息
            // 需要终止需要添加return 中断程序
            // return
        }
        finally {
            // 不管程序对不对 一定会执行的代码
            console.log("我一定会执行")
        }
        console.log("不终止,想终止加return")
    }
    fun()
</script>

总结:

1.try...catch 用于捕获错误信息

2.将预估可能发生错误的代码写在 try 代码段中

3.如果 try 代码段中出现错误后,会执行 catch 代码段,并截获到错误信息

4.finally 不管是否有错误,都会执行

debugger

调试的时候可以加上debugger 相当于直接就是断点

打开调试工具 然后按 F5 即可

感谢大家的阅读,如有不对的地方,可以向我提出,感谢大家!

相关推荐
云水一下18 小时前
从零开始!VMware安装Fedora Workstation 44桌面系统完整教程
前端
万粉变现经纪人19 小时前
如何解决 pip install llama-cpp-python 报错 未安装 CMake/Ninja 或 CPU 不支持 AVX 问题
开发语言·python·开源·aigc·pip·ai写作·llama
小码哥_常20 小时前
安卓黑科技:实现多平台商品详情页一键跳转APP
前端
清风明月一壶酒20 小时前
OpenClaw自动处理Word文档全流程
开发语言·c#·word
killerbasd20 小时前
还是迷茫 5.3
前端·react.js·前端框架
其实防守也摸鱼20 小时前
CTF密码学综合教学指南--第五章
开发语言·网络·笔记·python·安全·网络安全·密码学
不会敲代码121 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
kyriewen21 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·github·openai
小郑加油21 小时前
python学习Day12:pandas安装与实际运用
开发语言·python·学习
AC赳赳老秦21 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw