JS异常简单处理
有时候JS某一处报错会导致整个页面JS的运行出问题,于是想的简单研究一下JS的错误处理机制。更详细的可以自己参考网站研究: https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Errors
1.两个经常可能出现的错误
1.变量未定义
<!--异常JS,会导致后面的不能正常运行-->
<script type="text/javascript">
alert(b)
alert("这里是异常后的语句")
</script>
界面报错:

2.语法错误
<!--2.SyntaxError (语法错误异常) 测试-->
<script>
alert("sss"ssss"") //SyntaxError
</script>
界面报错:

2. 针对上面两个错误进行简单处理(以第一个错误为例子)。。自己感觉JS错误机制特别像Java的异常机制
1.try...catch... 进行简单处理
<!--try catch的使用-->
<script type="text/javascript">
try{
alert(b);
alert("这里是异常后的语句");//发生异常,所以不会执行到这里
}catch(error){
alert("发生异常了")
}
</script>
2.try..catch...finally...的使用
<!--try catch finally的使用-->
<script type="text/javascript">
try {
alert(b);
alert("这里是异常后的语句"); //发生异常,所以不会执行到这里
} catch (error) {
debugger
alert("发生异常了")
} finally {
alert("无论如何这里都会打印");
}
</script>
3.也可以直接try...finally...进行处理
<!--try finally的使用-->
<script type="text/javascript">
try{
alert(b);
alert("这里是异常后的语句");//发生异常,所以不会执行到这里
}finally{
alert("无论如何这里都会打印");
}
</script>
3.常见的错误类型
JS定义了7种错误类型,如下:
- Error ‰
- EvalError
- RangeError ‰
- ReferenceError ‰
- SyntaxError ‰
- TypeError ‰
- URIError
说明:
- Error类型是基本的错误类型,其他类型都继承自这个类型。
- EvalError 类型的错误会在使用 eval()函数而发生异常时被抛出
- TypeError 类型在 JavaScript 中会经常用到,在变量中保存着意外的类型时,或者在访问不存在的 方法时,都会导致这种错误
- 一般情况,不同的错误,处理方式不一样。
例如:
<!--try catch finally的使用-->
<script type="text/javascript">
try {
alert(b)
alert("这里是异常后的语句"); //发生异常,所以不会执行到这里
} catch (err) {
alert(err.name)//打印错误类型 ReferenceError
alert(err.message)//打印错误消息 b is not defined
if (err instanceof ReferenceError) {
alert("发生引用异常了")
} else if (err instanceof SyntaxError) {
alert("发生语法异常了")
} else {
alert("发生其他异常了")
}
} finally {
alert("无论如何这里都会打印");
}
</script>
4.巧用throw关键字抛出异常
1.抛出JS内置的错误异常类型
例如:
<script type="text/javascript">
function testerr() {
try {
alert(b)
alert("这里是异常后的语句"); //发生异常,所以不会执行到这里
} catch (err) {
if (err instanceof ReferenceError) {
throw new Error("引用异常");
} else if (err instanceof SyntaxError) {
throw new Error("语法异常");
} else {
throw new Error("其他异常");
}
}
} try{
testerr();
}catch(err){
alert(err.message)
}
</script>
会弹出 引用异常。
2.抛出自定义的错误异常类型
<script type="text/javascript">
/**
* 自定义异常类
* @param {Object} name 异常名称
* @param {Object} message 异常信息
*/
function MyError(name,message){
this.name = name;
this.message = message;
} function testerr() {
try {
alert(b)
alert("这里是异常后的语句"); //发生异常,所以不会执行到这里
} catch (err) {
if (err instanceof ReferenceError) {
throw new MyError("yyyc","引用异常");
} else if (err instanceof SyntaxError) {
throw new MyError("yyyc","语法异常");
} else {
throw new MyError("qtyc","其他异常");
}
}
} try{
testerr();
}catch(err){
alert(err.message)
alert(err.name)
} </script>
结果会弹出 引用异常 yyyc
5.项目种使用try...catch...
今天在使用amcharts插件的时候快速点击按钮刷新页面的时候报错,估计原因是刷新太快导致插件根据ID获取元素的时候获取不到元素,但是调用innerHtml的时候报错。
最后我的解决办法是try...catch... 包住报错的代码,在catch种用console.log打印记录错误信息。
而且try...catch...结合console.log也可以帮我们排错,每次try...catch...一小块代码,并且cosole.log()错误信息可以定位到出错的代码
在JS脚本的编写中,console.log也是进行日志记录的一种常用方式,类似于 我们在Java中的Logger进行日志记录,便于我们排错。
JS异常简单处理的更多相关文章
- JS 异常: Uncaught RangeError: Maximum call stack size exceeded
遇到了这个js异常, 总是吧浏览器搞崩溃,这是什么原因呢? 开始我也只能想到死循环, 也许是哪个条件判断写错了,其实不是.经过google,发现了一篇文章,内容请看: ================ ...
- JS的简单用法
JS的简单用法 参考:http://www.w3school.com.cn/js/js_switch.asp JavaScript 是网络的脚本语言 JavaScript 是可插入 HTML 页面的编 ...
- 原生JS封装简单动画效果
原生JS封装简单动画效果 一致使用各种插件,有时候对原生JS陌生了起来,所以决定封装一个简单动画效果,熟悉JS原生代码 function animate(obj, target,num){ if(ob ...
- Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换
Atitit 跨平台异常处理(2)--------异常转换 -----java c# js异常对象结构比较and转换 { "@type":"java.lang.Runti ...
- HTML(.js) – 最简单的方式操作 DOM 的 JS 库
HTML(.js) 是一个轻量的(压缩后~2kb) JavaScript 库,简化了与 DOM 交互的方法. 这个 JavaScript 库的方法可读性很好,并具有搜索和遍历 DOM 的方法.相比 j ...
- Sea.js提供简单、极致的模块化开发体验
为什么使用 Sea.js ? Sea.js 追求简单.自然的代码书写和组织方式,具有以下核心特性: 简单友好的模块定义规范:Sea.js 遵循 CMD 规范,可以像 Node.js 一般书写模块代码. ...
- 投票系统 & js脚本简单刷票
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 基于vue.js的简单用户管理
功能描述:添加.修改.搜索过滤 效果图: <!DOCTYPE html> <html lang="en"> <head> <title&g ...
- JS实现简单的运行代码 & 侧边广告
/* JS实现简单的运行代码功能 */<!doctype html> <html> <head> <meta charset="utf-8" ...
随机推荐
- 【MOOC EXP】Linux内核分析实验一报告
程涵 原创博客 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 [反汇编一个简单的C程序] 实验 ...
- 20135323符运锦----第三周:构建一个简单的Linux系统MenuOS
相关知识点 1.arch目录 占据相当庞大的空间,X86目录下代码需要重点关注. 2.init目录 内核启动的相关代码基本都在此目录下,内含MAIN.C,文件中START_KERNEL是整个LINUX ...
- C#获取每月最后一天或者最末一天的方法
/// <summary> /// 取得某月的第一天 /// </summary> /// <param name="datetime">要取得 ...
- 团队作业(五)——旅游行业的手机App
首先是作业要求: 在PM 带领下, 每个团队深入分析下面行业的App, 找到行业的Top 5 (从下面的三个备选中,任选一个行业即可) 英语学习/词典App 笔记App 旅游行业的手机App 我们选择 ...
- VSCode和VUE的初始安装及简单使用入门
(版本1.0) npm run dev 运行工程 PS F:\SDN\VIMS--前端\vue> cnpm install PS F:\SDN\VIMS--前端\vue> cnpm reb ...
- Beta阶段敏捷冲刺①
1.提供当天站立式会议照片一张. 每个人的工作 (有work item 的ID),并将其记录在码云项目管理中: 1.1昨天已完成的工作. 姓名 昨天已完成的工作 徐璐琳 熟悉"慧记" ...
- Beta阶段敏捷冲刺总结
设想和目标 1. 我们的软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 在最开始的时候我们就是为了解决集美大学计算机工程学院网页没有搜索引擎的问题.因为没有搜 ...
- 第九周PSP&进度条
PSP 一.表格: D日期 C类型 C内容 S开始时间 E结束时间 I时间间隔 T净时间(mins) 预计花费时间(mins) 11月11号 讨论 讨论beta发布 09:00 09:54 1 ...
- linux 开机直接进入命令行
一.图形界面和命令行切换 linux系统在启动图形化界面后,可以在图形界面和命令行之间来回切换,linux提供了6个命令行终端(terminal或Console),分别为tty1——tty6,使用Ct ...
- Python面向对象高级编程:@property--把方法变为属性
为了限制score的范围,可以通过一个set_score()方法来设置成绩,再通过一个get_score()来获取成绩,这样,在set_score()方法里,就可以检查参数: >>> ...