首页
学习
活动
专区
圈层
工具
发布

JavaScript 开发中常见错误解决小总结

错误类型:ReferenceError ReferenceError 这类错误通常是指找不到引用,当出现这类错误时在 IDE 中不一定会提示现错误(除非安装了 Linter),所以在代码的运行阶段才会看到这类错误...❝排查重点: 通过 Chrome 的提示改正 在 JavaScript 开发环境中安装 ESLint ❞ ReferenceError: a is not defined ReferenceError...: a is not defined 引用错误:由于变量 a 未定义,所以在使用这个变量时会出现未定义的提示,只要先定义好这个变量即可。...下面的例子就是因为 jQuery 没有正确导入而导致的。...这类错误也很常见,却不容易找到出错的原因,其主要原因是在递归时超过了环境的限制(使用框架时也很常见),如果遇到这错误建议改写当前调用函数的方式。

4.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    一篇文章教你如何捕获前端错误

    常见错误的分类 对于用户在访问页面时发生的错误,主要包括以下几个类型: 1、js运行时错误 JavaScript代码在用户浏览器中执行时,由于一些边界情况、本地环境的不可控等因素,可能会存在js运行时错误...e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: ? 2、资源加载错误 这里的静态资源包括js、css以及image等。...3、未处理的promise错误 未使用catch捕获的promise错误,往往都会存在比较大的风险。而编码时有可能覆盖的不够全面,因此有必要监控未处理的promise错误并进行上报。...像axios和jQuery等库就是在xhr上的封装,而有些情况也可能会使用原生的fetch,因此对这两种情况都要进行捕获。 e.g: 下图是xhr请求接口返回400时捕获后的上报数据: ?...('error')都能捕获,但是window.onerror含有详细的error堆栈信息,存在error.stack中,所以我们选择使用onerror的方式对js运行时错误进行捕获。

    5.4K40

    JS 面试总结 理论篇

    在XHR运行中,当其属性readyState改变时readystatechange事件就会被触发, 只有在XHR从远端服务器接收响应结束时回调函数才会触发执行。...是什么实现的 捕获异常的方法通过使用 try...catch try { var a = 1; var b = a + c; } catch (e) { // 捕获处理...console.log(e); // ReferenceError: c is not defined } 缺点:增加代码量和维护性,不适用于整个项目的异常捕获。...在MVVM框架中如果你一如既往的想使用window.onerror来捕获异常,那么很可能会竹篮打水一场空,或许根本捕获不到,因为你的异常信息被框架自身的异常机制捕获了。...使用Vue.config.errorHandler这样的Vue全局配置,可以在Vue指定组件的渲染和观察期间未捕获错误的处理函数。这个处理函数被调用时,可获取错误信息和Vue 实例。

    1.8K30

    一篇文章教你如何捕获前端错误

    e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: 2、资源加载错误 这里的静态资源包括js、css以及image等。...e.g: 下图是图片资源不存在时的上报数据: 3、未处理的promise错误 未使用catch捕获的promise错误,往往都会存在比较大的风险。...像axios和jQuery等库就是在xhr上的封装,而有些情况也可能会使用原生的fetch,因此对这两种情况都要进行捕获。...使用window.onerror和window.addEventListener('error')都能捕获,但是window.onerror含有详细的error堆栈信息,存在error.stack中,...当网站请求并执行一个托管在第三方域名下的脚本时,就可能遇到该错误。最常见的情形是使用 CDN 托管 JS 资源。 其实这并不是一个 JavaScript Bug。

    4.4K90

    javaScript代码飘红报错看不懂?读完这篇文章再试试!

    ] 范围;界限;区间; 类; 种; token [ˈtəʊkən] 令牌;标记 try [traɪ] 尝试 throw [θrəʊ] 投;掷;抛;扔;摔;丢;猛推;使劲撞 Uncaught 未捕获...常见的四种Error类型 1、ReferenceError(引用错误):使用了未定义的变量。...// 1、变量未定义便直接使用 console.log(my); // 报错:Uncaught ReferenceError: my is not defined // 翻译:my未定义 // 2、将变量赋值给一个无法被赋值的东东...原因:对象中属性与其对应的值之间使用“=” // 语法错误有很多,在此就不一一列举了 三、通过try...catch处理Error 1、被try包裹的代码块一旦出现Error,会将Error传递给catch...•使用try包裹的代码,即使不出错,效率也比不用try包裹的代码低。•在try中,尽量少的包含可能出错的代码。•无法提前预知错误类型的错误,必须用try catch捕获。•finally可以省略。

    9.1K20

    【JavaScript】解决 JavaScript 语言报错:Uncaught ReferenceError: XYZ is not defined

    一、背景介绍 在 JavaScript 编程中,“Uncaught ReferenceError: XYZ is not defined” 是一种常见的错误。...这种错误通常发生在试图使用一个未声明的变量或标识符时。这类错误可以在调试和开发过程中频繁遇到,了解其成因和解决方法对于提升代码质量和开发效率非常重要。...二、报错信息解析 “Uncaught ReferenceError: XYZ is not defined” 错误信息可以拆解为以下几个部分: Uncaught ReferenceError: 这表示一个未被捕获的引用错误...变量未声明 console.log(foo); // Uncaught ReferenceError: foo is not defined 在这个例子中,foo 没有被声明,因此访问它时会抛出错误。...使用未定义的函数或对象 myFunction(); // Uncaught ReferenceError: myFunction is not defined 此例中,myFunction 函数未定义或声明

    3K20

    你必须掌握的 7 种 JavaScript 错误类型

    将在env记录中搜索该变量,当找到初始未定义值时,该赋值将被覆盖。...can't find it 注意:未定义的变量不会抛出ReferenceError,因为它存在于环境记录中只是它的值尚未设置。...当我们键入JS引擎可以理解的代码时,会发生此错误。 解析期间,JS引擎捕获了此错误。 在JS引擎中,我们的代码经过不同的阶段,然后才能在终端上看到这些结果。...6.EvalErro 在使用全局eval()函数时,此函数用于识别错误。 根据EcmaSpec 2018版: 此规范当前未使用此异常。 保留该对象是为了与本规范的先前版本兼容。...我们在这篇文章中列出了它们,并提供了一些示例来说明它们是如何遇到的。 因此,无论何时在终端或浏览器中引发错误,您现在都可以轻松发现错误发生的位置和方式,并编写更好,更不易出错的代码。

    6.2K10

    使用断点调试代码「建议收藏」

    简单地说,断点调试是指自己在程序的某一行设置一个断点,调试时,程序运行到这一行就会停住,然后你可以一步一步往下调试,调试过程中可以看各个变量当前的值,出错的话,调试到出错的代码行即显示错误,停下。...在web开发中,打断点是经常使用的调试代码的方法,现在在这里简略的翻译一下官方对此功能的讲解,并插入一些自己的说明。...操作: f12 -> Source Tab -> 点击 Pause on exceptions 暂停图标 -> 图标变成蓝色,表明启用了在未捕获到的异常出现的时候断点的功能。...如果是所有异常都中断(勾选了 Pause On Caught Exceptions),那么代码执行到会产生异常的 throw 语句时就会自动中断;而如果是仅遇到未捕获异常才中断,那么这里就不会中断。...一般我们会更关心遇到未捕获异常的情况。 ---- Function breakpoints 在你希望 debug 一个具体的函数时使用。功能与在此函数的第一行代码出打断点是一样的。

    2K20

    你应该知道的7 个 JavaScript 原生错误类型

    将在环境记录中搜索该变量,当发现它未定义值时,该赋值将被覆盖。...can't find it 注意:未定义的变量不会抛出 ReferenceError,因为它在于环境记录中的值尚未设置。 3. SyntaxError 这是最常见的错误。...当我们输入 JS 引擎不能理解的代码时,就会发生这个错误。 JS 引擎在解析期间捕获了这个错误。在 JS 引擎中,我们的代码经历了不同的阶段,然后才能在终端上看到结果。...根据 EcmaSpec 2018 版: 此规范当前未使用此异常。保留它目的是为了与本规范的先前版本兼容。 7....所以无论什么时候在终端或浏览器中引发错误,你都可以轻松发现错误产生的位置和方式,并能够编写更好、更不易出错的代码。

    4.3K20

    前端项目里常见报错

    如果绑定了onclick事件,就会出现这样的错误,是因为W3School的写法是浏览器先加载完按钮节点才执行的js,所以当浏览器自顶向下解析时,找不到onclick绑定的按钮节点,于是报错。...localhost are already in use 8080端口被占用 将配置文件里面被占用的端口名改掉: 做一个项目的时候 ,控制台总是会出现各种bug,其实不用慌张,终结起来也就几种类型的错误,在开发中每次遇到错误都善于总结...,下次在看到就会胸有成竹知道是什么情况了,以下是在开发过程中总结的一些错误以及错误的解决方法。...#报错六:Uncaught ReferenceError: $ is not defined Uncaught ReferenceError: $ is not defined Uncaught ReferenceError...像这样使用它,解决了我的问题!

    42100

    bootsrap+jquery+组件项目引入文件的常见报错报错一:Uncaught ReferenceError: $ is not defined报错二:jsp页面相对路径和绝对路径的问题:报错三:

    做一个项目的时候 ,控制台总是会出现各种bug,其实不用慌张,终结起来也就几种类型的错误,在开发中每次遇到错误都善于总结,下次在看到就会胸有成竹知道是什么情况了,以下是在开发过程中总结的一些错误以及错误的解决方法...报错一:Uncaught ReferenceError: $ is not defined Uncaught ReferenceError: $ is not defined Uncaught ReferenceError...图片.png 解决办法:在和之间插入以下代码 <% String path = request.getRequestURI(); String basePath...像这样使用它,解决了我的问题!...图片.png 解决方案:解决方案:将jquery.min.js放在bootstrap.min.js文件之前引用,bootstrap.min.css文件在整两个文件前后引用都无妨(测试多次)。

    27K40

    JavaScript立即执行函数(IIFE)的使用

    foo; // ReferenceError: foo is not defined 现在的论点是,不使用IIFE,我们可以使用块范围变量来获得相同的结果。...假设我们要创建一个函数uniqueId,每次调用它时都会返回一个唯一标识符(如“id_1”,“id_2”等)。在IIFE中,我们将跟踪每次调用计数器函数时递增的私有计数器变量。...$) { // ... })(jQuery); 不管在外部作用域有什么值指定给$,在IIFE中,这些值都会被”屏蔽”,$参数一直指向jQuery方法。...捕获全局对象 JavaScript代码在不同环境执行时,你所使用的全局对象是不同的。当代码在浏览器运行时,全局对象是windows。但是在Node.js中,全局对象是global。...由于在写通用的JavaScript代码时,你肯定不想硬编码这两个名字其中的任何一个,这时你就可以使用一种”包装”的方式就像下面这样: (function(global) { // ... }

    3K20

    前端项目里常见的十种报错及其解决办法

    如果绑定了onclick事件,就会出现这样的错误,是因为W3School的写法是浏览器先加载完按钮节点才执行的js,所以当浏览器自顶向下解析时,找不到onclick绑定的按钮节点,于是报错。...already in use 图片.png 8080端口被占用 将配置文件里面被占用的端口名改掉: 图片.png 做一个项目的时候 ,控制台总是会出现各种bug,其实不用慌张,终结起来也就几种类型的错误,在开发中每次遇到错误都善于总结...,下次在看到就会胸有成竹知道是什么情况了,以下是在开发过程中总结的一些错误以及错误的解决方法。...报错六:Uncaught ReferenceError: $ is not defined Uncaught ReferenceError: $ is not defined Uncaught ReferenceError...像这样使用它,解决了我的问题!

    98610

    项目引入文件的常见报错

    做一个项目的时候 ,控制台总是会出现各种bug,其实不用慌张,终结起来也就几种类型的错误,在开发中每次遇到错误都善于总结,下次在看到就会胸有成竹知道是什么情况了,以下是在开发过程中总结的一些错误以及错误的解决方法...#报错一:Uncaught ReferenceError: $ is not defined Uncaught ReferenceError: $ is not defined Uncaught ReferenceError...: jQuery is not defined 错误原因:文件加载的顺序不对,jQuery文件的顺序要在前面 方法:把jQuery文件写在所有script文件前面 #报错二:jsp页面相对路径和绝对路径的问题...: 正常路径:html里面的…/…/,改成jsp页面就找不到路径了,这个时候成了这个鬼样子 这时候,只需要在文件里面加入这段代码: 解决办法:在和之间插入以下代码 <% String path...像这样使用它,解决了我的问题!

    26900

    django滑动验证码

    一、概述 最近用django写了一个后台系统,使用的是验证码方式。但是开发人员抱怨,输入验证太麻烦,还有可能出错,太影响效率了。 是否可以用滑动验证码,一拖动就可以了!...免费jquery插件 我在网上找了一款免费的jquery插件,链接如下: http://www.htmleaf.com/jQuery/Form/201711064813.html verify.js是一款功能强大的...jquery验证码插件。...演示地址: http://www.htmleaf.com/Demo/201711064814.html 二、django项目演示 完整代码 上面的链接,已经介绍了verify.js如何使用。...每次刷新页面时,随机从里面选择一张图片。 如果觉得图片太少了,可以修改此变量,多增加几张图片。 运行项目 python3 manage.py runserver 0.0.0.0:8000 效果图 ?

    2.5K41
    领券