JS常见错误(Error)及处理方案详解


Posted in Javascript onJuly 02, 2020

 1. 错误的类型

Error: 所有错误的父类型

错误的子类型包括:

  • ReferenceError: 引用的变量不存在

  • TypeError: 数据类型不正确的错误

  • RangeError: 数据值不在其所允许的范围内

  • SyntaxError: 语法错误

常见的内置错误:

(1)ReferenceError: 引用变量不存在

console.log(a) //ReferenceError: a is not defined

(2)TypeError: 数据类型不正确

var b = {}
b.xxx() //TypeError: b.xxx is not a function

(3)RangeError: 数据值不在其所允许的范围内

function fn(){
fn()
}
fn() //RangeError: Maximum call stack size exceeded

(4)SyntaxError: 语法错误

const c = """" //SyntaxError: Unexpected string

2. 错误处理

捕获错误: try ... catch

抛出错误: throw error

(1)捕获错误

try {
  let d
  console.log(d.xxx)
} catch (error) { //可以通过调试查看error对象的属性(message属性: 错误相关信息;stack属性: 函数调用栈记录信息)
 console.log(error.message)
 //console.log(error.stack)
}
// 可以继续向下执行
console.log('出错之后')

(2)抛出错误

function something() {
  if (Date.now() % 2 === 1 ){
  console.log('当前时间为奇数,可执行任务')
  } else {
  throw new Error('当前时间为偶数无法执行任务')
  }
}

//情况1 直接调用
something() //Error: 当前时间为偶数无法执行任务
console.log('something之后') //不会继续这句代码(没有对异常进行处理)

//情况2 捕获处理异常
try {
 something()
} catch(error) {
 console.log(error.message)
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
兼容ie和firefox js关闭代码
Dec 11 Javascript
jQuery+PHP打造滑动开关效果
Dec 16 Javascript
javascript结合fileReader 实现上传图片
Jan 30 Javascript
JS+CSS实现简单滑动门(滑动菜单)效果
Sep 19 Javascript
深入浅析JavaScript中的Function类型
Jul 09 Javascript
详解JSON1:使用TSQL查询数据和更新JSON数据
Nov 21 Javascript
vue2.0开发实践总结之入门篇
Dec 06 Javascript
bootstrap css样式之表单
Jan 19 Javascript
vue.js实现请求数据的方法示例
Feb 07 Javascript
jquery实现图片跟随鼠标的实例
Oct 17 jQuery
解决vue单页使用keep-alive页面返回不刷新的问题
Mar 13 Javascript
Vant picker 多级联动操作
Nov 02 Javascript
vue过滤器实现日期格式化的案例分析
Jul 02 #Javascript
Vue使用预渲染代替SSR的方法
Jul 02 #Javascript
node运行js获得输出的三种方式示例详解
Jul 02 #Javascript
基于小程序请求接口wx.request封装的类axios请求
Jul 02 #Javascript
JS异步宏队列与微队列原理区别详解
Jul 02 #Javascript
微信小程序自定义扫码功能界面的实现代码
Jul 02 #Javascript
JS字符串和数组如何实现相互转化
Jul 02 #Javascript
You might like
php Smarty date_format [格式化时间日期]
2010/03/15 PHP
php开发文档 会员收费1期
2012/08/14 PHP
CodeIgniter生成网站sitemap地图的方法
2013/11/13 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(八)
2014/06/23 PHP
简单谈谈favicon
2015/06/10 PHP
thinkphp3.x中display方法及show方法的用法实例
2016/05/19 PHP
浅谈PHP链表数据结构(单链表)
2016/06/08 PHP
使用PHP下载CSS文件中的所有图片【几行代码即可实现】
2016/12/14 PHP
使用PHP连接多种数据库的实现代码(mysql,access,sqlserver,Oracle)
2016/12/21 PHP
Yii2框架实现数据库常用操作总结
2017/02/08 PHP
javascript 有用的脚本函数
2009/05/07 Javascript
mysql输出数据赋给js变量报unterminated string literal错误原因
2010/05/22 Javascript
jQuery总体架构的理解分析
2011/03/07 Javascript
微信JS-SDK选取手机照片上传功能
2017/04/21 Javascript
js实现省市级联效果分享
2017/08/10 Javascript
Vue中引入样式文件的方法
2017/08/18 Javascript
vue2实现可复用的轮播图carousel组件详解
2017/11/27 Javascript
JavaScript变量提升和严格模式实例分析
2019/01/27 Javascript
微信小程序Echarts覆盖正常组件问题解决
2019/07/13 Javascript
微信小程序使用GoEasy实现websocket实时通讯
2020/05/19 Javascript
[09:37]2018DOTA2国际邀请赛寻真——不懈追梦的Team Serenity
2018/08/13 DOTA
布同 统计英文单词的个数的python代码
2011/03/13 Python
用python删除java文件头上版权信息的方法
2014/07/31 Python
Python heapq使用详解及实例代码
2017/01/25 Python
Python通过调用mysql存储过程实现更新数据功能示例
2018/04/03 Python
python之pyqt5通过按钮改变Label的背景颜色方法
2019/06/13 Python
乐高积木玩具美国官网:LEGO Shop US
2016/09/16 全球购物
世界上最大的街头服饰网站:Karmaloop
2017/02/04 全球购物
线程问题:wait()方法是定义在哪个类里面
2015/07/07 面试题
JavaScript实现前端网页版倒计时
2021/03/24 Javascript
打架检讨书400字
2014/01/17 职场文书
仓库主管岗位职责
2014/03/02 职场文书
2014年3.15团委活动总结
2014/03/16 职场文书
大学学生会竞选演讲稿
2014/04/25 职场文书
2016年中秋节寄语大全
2015/12/07 职场文书
Python import模块的缓存问题解决方案
2021/06/02 Python