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 相关文章推荐
计算世界完全对称日的js代码,粗糙版
Nov 04 Javascript
javascript + jquery实现定时修改文章标题
Mar 19 Javascript
JavaScript获取页面中超链接数量的方法
Nov 09 Javascript
简单实现jQuery进度条轮播实例代码
Jun 20 Javascript
JS实现间歇滚动的运动效果实例
Dec 22 Javascript
canvas 绘制圆形时钟
Feb 22 Javascript
浅谈vue-lazyload实现的详细过程
Aug 22 Javascript
p5.js入门教程之平滑过渡(Easing)
Mar 16 Javascript
vue实现树形菜单效果
Mar 19 Javascript
在vue项目中,将juery设置为全局变量的方法
Sep 25 Javascript
vue刷新页面时去闪烁提升用户体验效果的实现方法
Dec 10 Javascript
Canvas跟随鼠标炫彩小球的实现
Apr 11 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执行速度全攻略(下)
2006/10/09 PHP
php 防止单引号,双引号在接受页面转义
2008/07/10 PHP
Window 7/XP 安装Apache 2.4与PHP 5.4 的过程详解
2013/06/02 PHP
PHP实现XML与数据格式进行转换类实例
2015/07/29 PHP
thinkPHP事务操作简单案例分析
2019/10/17 PHP
laravel框架使用极光推送消息操作示例
2020/02/15 PHP
为调试JavaScript添加输出窗口的代码
2010/02/07 Javascript
JavaScript高级程序设计 阅读笔记(十二) js内置对象Math
2012/08/14 Javascript
js 跳出页面的frameset框架示例介绍
2013/12/23 Javascript
Javascript中使用A标签获取当前目录的绝对路径方法
2015/03/02 Javascript
Jquery代码实现图片轮播效果(一)
2015/08/12 Javascript
JS判断输入字符串长度实例代码(汉字算两个字符,字母数字算一个)
2016/08/02 Javascript
js继承实现方法详解
2016/12/16 Javascript
基于Bootstrap table组件实现多层表头的实例代码
2017/09/07 Javascript
微信小程序实现添加手机联系人功能示例
2017/11/30 Javascript
使用elementUI实现将图片上传到本地的示例
2018/09/04 Javascript
在vue中使用v-bind:class的选项卡方法
2018/09/27 Javascript
使用异步组件优化Vue应用程序的性能
2019/04/28 Javascript
JavaScript中callee和caller的区别与用法实例分析
2019/06/28 Javascript
Vue 中使用 typescript的方法详解
2020/02/17 Javascript
vue实现列表滚动的过渡动画
2020/06/29 Javascript
js实现筛选功能
2020/11/24 Javascript
python实现猜数字游戏(无重复数字)示例分享
2014/03/29 Python
pymongo实现多结果进行多列排序的方法
2015/05/16 Python
Python中基础的socket编程实战攻略
2016/06/01 Python
Python操作csv文件实例详解
2017/07/31 Python
Python中实现最小二乘法思路及实现代码
2018/01/04 Python
pytorch ImageFolder的覆写实例
2020/02/20 Python
全网首秀之Pycharm十大实用技巧(推荐)
2020/04/27 Python
Kears 使用:通过回调函数保存最佳准确率下的模型操作
2020/06/17 Python
Alpine安装Python3依赖出现的问题及解决方法
2020/12/25 Python
澳大利亚冲浪和时尚服装网上购物:SurfStitch
2017/07/29 全球购物
SEPHORA丝芙兰捷克官网:购买香水、化妆品和护肤品
2018/11/26 全球购物
科级干部培训心得体会
2016/01/06 职场文书
告诉你一个秘密:富人致富的五大优点
2019/07/11 职场文书
MyBatis XPathParser解析器使用范例详解
2022/07/15 Java/Android