首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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

常见错误的分类 对于用户在访问页面时发生的错误,主要包括以下几个类型: 1、js运行时错误 JavaScript代码在用户浏览器中执行时,由于一些边界情况、本地环境的不可控等因素,可能会存在js运行时错误...而依赖客户端的某些方法,由于兼容性或者网络等问题,也有概率会出现运行时错误。 e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: ?...像axios和jQuery等库就是在xhr上的封装,而有些情况也可能会使用原生的fetch,因此对这两种情况都要进行捕获。 e.g: 下图是xhr请求接口返回400时捕获后的上报数据: ?...('error')都能捕获,但是window.onerror含有详细的error堆栈信息,存在error.stack中,所以我们选择使用onerror的方式对js运行时错误进行捕获。...console.log(event.reason); }); (滑动查看) 4、fetch与xhr错误的捕获 对于fetch和xhr,我们需要通过改写它们的原生方法,在触发错误时进行自动化的捕获和上报

3.8K40

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

,主要包括以下几个类型: 1、js运行时错误 JavaScript代码在用户浏览器中执行时,由于一些边界情况、本地环境的不可控等因素,可能会存在js运行时错误。...e.g: 下图是当使用了未定义的变量"foo",导致产生js运行时错误时的上报数据: 2、资源加载错误 这里的静态资源包括js、css以及image等。...像axios和jQuery等库就是在xhr上的封装,而有些情况也可能会使用原生的fetch,因此对这两种情况都要进行捕获。...console.log(event.reason); }); 4、fetch与xhr错误的捕获 对于fetch和xhr,我们需要通过改写它们的原生方法,在触发错误时进行自动化的捕获和上报。...解决方案2 难以在 HTTP 请求响应头中添加跨域属性时,还可以考虑 try catch 这个备选方案。 在如下示例 HTML 页面中加入 try catch: <!

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

    2016 JavaScript 技术栈展望

    对于类似运行 Webpack 的基本任务,我建议直接使用 NPM 脚本。 Mocha + Chai + Sinon 在 JavaScript 中,有大量可选的单元测试工具,每一个都很稳定和健壮。...我对一个测试框架的要求有如下几条: 可以在浏览器运行,便于调试 执行速度快 便于处理异步测试 便于在命令行中使用 可以兼容任意断言和数据模拟的第三方库 第一条标准就排除了 Ava 和 Jest。...我喜欢让项目保持简洁,在代码中只使用 fetch 。fetch 基于 promise,Firefox 和 Chrome 都封装了该接口。对于其他浏览器,则需要提供一个腻子脚本。...我建议使用 isomorphic-fetch 在各个浏览器和服务端保持功能的一致性。 当然也可以其他优秀的第三方库异步获取数据,但我觉得 fetch 已经够用了。...我不认为上述有一个完美的解决方案,但我对 API 有一个自己的认知: 可预测,遵循一致性协议 支持在一次查询中获取多个实体 支持更新操作 易于调试 易于使用 到目前为止,我还没有发现满足上述所有条件的解决方案

    2.1K40

    浅谈 2022 前端工作流中全流程多层次的四款测试工具

    在应届生找工作的时候,我们经常会见到一条招聘要求:要求实习经历。或者 有实习经历者优先。为什么大部分公司在招聘时,都要求你必须有实习经历?...商业项目与个人项目不同,一段实习经历,能够熟悉公司中成熟的规范化的整个开发流程。在大学中,当你编写网站时,你大概率编写的是一个复杂度较低的网站,几乎是一人搞定所有工作。...图片以 React 为例,在 React 中,可以使用 React Testing Library 对 React Component 进行测试。...图片当你在 Apifox 设计好 API 及其数据类型时,你的 API 文档与测试也已自动完成,几乎零配置,当然,你也可以添加更为精细的测试。...图片小结从本篇文章中,我们知道了前端工作中的各个分层以及职责,最重要的是对于代码开发所做的测试以及几款工具软件的推荐,如下所示:单元测试:mocha/chaiComponent 测试:react-testing-library

    43130

    写代码无BUG,网易云前端单元测试方案总结

    因为运行在不同环境中需要的包格式不同,所以需要我们针对不同环境做不同的包格式转换,为了了解在不同端跑单元测试需要做哪些事情,可以先来了解一下常见的包格式。...,所以在搭建测试工具链时要确定自己运行在什么环境中,如果在 Node 中只需要加一层 babel 转换,如果是在真实浏览器中,则需要增加 webpack 处理步骤。...karma browser 可以看到现在已经在真实浏览器中运行测试程序了。 因为图形化的测试对 CI 机器不友好,所以可以选择 puppeteer 代替 Chrome。...上面的内容介绍了 chai , mocha , karma , jasmine 和 jest, 每种工具分别对应一些自己特有的工具链,在选取合适的测试工具时根据实际需要选择, 测试领域还有非常多的工具数都数不过来...另外测试 React组件除了 Enzyme 提供的操作, Jest 中还有很多其他有用的特性,比如可以 mock 一个 npm 组件的实现,调整 setTimeout 时钟等,真正进行单元测试时,这些工具也是必不可少的

    9.6K20

    用不了多久 Web Component,就能取代你的前端框架吗?

    在实际插入DOM前,它是不可见也不可解析的。这意味着定义在内部的任何资源都无法获取,任何内部定义的CSS和JavaScript只有当它被插入DOM中时,才会被执行。...不需要转换或者复杂的设置,只需要创建元素,并将其添加到DOM中并运行测试。...这意味着我们测试文件也需要作为一个ES6模块加载到浏览器中农。这需要以下的index.html能够在浏览器中运行测试。... mocha"> 在加载完所需的scripts后,我们暴露chai.assert作为一个全局变量,因此我们可以在测试中简易的使用...然后加载测试文件,并调用mocha.run()运行测试。 请注意,在使用ES6模块化时,还需要将mocha.run()放在type=”module”的script中。

    2.3K40

    JavaScript 应用程序中的有效错误处理

    ; // 缺少右括号运行时错误:运行时错误,也称为异常,发生在代码执行期间。它们通常由逻辑错误、意外输入或对环境的错误假设引起。例如,访问未定义的变量或在空对象上调用方法。...异步/等待错误处理:随着 JavaScript 中异步编程的广泛使用,处理异步操作中的错误至关重要。在使用 async/await 时,try-catch 机制适用于异步代码。...('不能除以零');});使用 Jest 或 Mocha 等工具测试错误场景有助于保持错误处理代码的可靠性。...使用错误边界(React 应用程序):在 React 应用程序中,错误边界的概念允许开发人员捕获组件树中任何位置的 JavaScript 错误。这可以防止整个应用程序因一个组件中的单个错误而崩溃。...请记住提供描述性错误消息、记录错误以供分析、实现优雅降级、在 React 应用程序中使用错误边界以及充分测试错误场景。

    17100

    【Web技术】264- Web Component可以取代你的前端框架吗?

    在实际插入DOM前,它是不可见也不可解析的。这意味着定义在内部的任何资源都无法获取,任何内部定义的CSS和JavaScript只有当它被插入DOM中时,才会被执行。...不需要转换或者复杂的设置,只需要创建元素,并将其添加到DOM中并运行测试。...这意味着我们测试文件也需要作为一个ES6模块加载到浏览器中农。这需要以下的index.html能够在浏览器中运行测试。... mocha"> 在加载完所需的scripts后,我们暴露chai.assert作为一个全局变量,因此我们可以在测试中简易的使用...然后加载测试文件,并调用mocha.run()运行测试。 请注意,在使用ES6模块化时,还需要将mocha.run()放在type="module"的script中。

    2.6K30

    推荐一波实用高效的 NPM 工具包,总有几款适合你

    你们团队正在协作开发,并希望在整个团队中推行一套编码标准?没问题!有了 Husky,你就可以要求所有人在提交或推送到存储库之前自动完成 lint 并测试其代码。...您可以通过易于上手且功能丰富的 API 编写测试,从而快速获取结果。 jest-office 安装及示例 yarn add --dev jest 测试sum函数,这个函数的功能是两数相加。.../sum.test.js ✓ adds 1 + 2 to equal 3 (5ms) Mocha Mocha[18] 是一个功能丰富的 javascript 测试框架,运行在 node.js 和浏览器中...Mocha 测试连续运行,允许灵活和准确的报告,同时将未捕获的异常映射到正确的测试用例。 安装及示例 yarn add mocha --dev 接下来,创建名为 test.js 的文件。...可以通过以下方法列出所有正在运行的应用程序: $ pm2 ls 查阅官方文档[22],以获取 PM2 功能给的完整列表。

    4.3K40

    对 React 组件进行单元测试

    React 单元测试中用到的工具 Jest 不同于"传统的"(其实也没出现几年)的 jasmine / Mocha / Chai 等前端测试框架 -- Jest的使用更简单,并且提供了更高的集成度、更丰富的功能...” , 这也是 TDD 中的一般性步骤: 添加一个测试 运行所有测试,看看新加的这个是不是失败了;如果能成功则重复步骤1 根据失败报错,有针对性的编写或改写代码;这一步的唯一目的就是通过测试,先不必纠结细节...明确指定 PropTypes 对于一些之前定义并不清晰的组件,可以统一引入 prop-types,明确组件可接收的props;一方面可以在开发/编译过程中随时发现错误,另外也可以在团队中其他成员引用组件时形成一个明晰的列表.../modal 在一个项目中用到了 react-bootstrap 界面库,测试一个组件时,由于包含了其 Modal 模态弹窗,而弹窗组件是默认渲染到 document 中的,导致难以用普通的 find..._modalClass = FakeReactBootstrapModal; } } 这样测试即可顺利进行,跳过了并不重要的 UI 效果,而各种逻辑都能被覆盖了 模拟fetch请求 在单元测试的过程中

    4.3K40

    web前端好帮手 - Jest单元测试工具

    不支持原生并行测试 断言库要另外安装 测试覆盖率统计功能要另外安装 原生输入的测试报告可读性很差,格式化也要另外安装 不支持snapshot,要另外安装第三方插件 Mocha使用过程中要安装大量第三方模块安装维护...以至于我每次想写Mocha单元测试时,都要花半天去重读他的文档,这个过程让我逐渐地变得“害怕”写单元测试。...而现在只需要运行npm install -D jest一键安装Jest,便可以快速接入单元测试编写中。...基于以上划分,测试逻辑和范围就很清晰了: url.parse方法支持: 解析一般url 解析带hash的url 解析url片段 url.getParameter方法支持: 从指定url中获取查询参数 从浏览器地址中获取查询参数...当url中参数为空时 获取url参数返回值经过decode Webstorm测试界面能看到清晰的分组: ?

    5K40

    2020前端开发学习路线

    2、前后端网页交互:用户操作-->获取参数-->给后端发请求-->将响应展示给用户! 3、Node.js + 前端框架:使用成熟的技术,大幅度提升工作效率。并通过node.js进行后端开发!...flex理解和用法等...) 3、JS语言基础知识(继承都有哪些方法、什么叫闭包及应用场景、函数防抖&函数节流、异步promise、async/await、xmlHttpRequest / ajax / fetch...、react-router、redux、mobx、mobx-state-tree、elementUI、iVeiw、materialUI、Ant Design等...) 5、测试框架(jest、mocha...35K **进阶前端技术:** 1、多端小程序(微信小程序基础开发、公众号jssdk、Wepy、Taro、mp-vue、等...) 2、数据可视化(Echart、D3等...) 3、Native App原生开发...,不过这个是次要的,不用花费太多精力,但是脑中要理解和实战中能够运用。

    92600

    让我告诉你一些强无敌的 NPM 软件包

    你们团队正在协作开发,并希望在整个团队中推行一套编码标准?没问题!有了 Husky,你就可以要求所有人在提交或推送到存储库之前自动完成 lint 并测试其代码。...您可以通过易于上手且功能丰富的 API 编写测试,从而快速获取结果。 安装及示例 yarn add --dev jest 复制代码 测试sum函数,这个函数的功能是两数相加。.../sum.test.js ✓ adds 1 + 2 to equal 3 (5ms) 复制代码 Mocha Mocha 是一个功能丰富的 javascript 测试框架,运行在 node.js 和浏览器中...Mocha 测试连续运行,允许灵活和准确的报告,同时将未捕获的异常映射到正确的测试用例。 安装及示例 yarn add mocha --dev 复制代码 接下来,创建名为 test.js 的文件。...可以通过以下方法列出所有正在运行的应用程序: $ pm2 ls 复制代码 查阅官方文档,以获取 PM2 功能给的完整列表。

    1.9K20

    10 种 JavaScript 最常见的错误

    当你读取一个未定义的对象的属性或调用其方法时,这个错误会在 Chrome 中出现。 您可以很容易的在 Chrome 开发者控制台中进行测试。 ?...当异步获取数据时,不管它是在构造函数 componentWillMount 还是 componentDidMount 中获取的,组件在数据加载之前至少会呈现一次,当 Quiz 第一次呈现时, this.state.items...2、 TypeError: ‘undefined’ is not an object 这是在 Safari 中读取属性或调用未定义对象上的方法时发生的错误。...5、 TypeError: Object doesn’t support property 这是您在调用未定义的方法时发生在 IE 中的错误。 您可以在 IE 开发者控制台中进行测试。 ?...ReferenceError: event is not defined 当您尝试访问未定义的变量或超出当前作用域的变量时,会引发此错误。 您可以在 Chrome 浏览器中测试。 ?

    8.6K20

    2018年前端流行哪些技术?

    我主要是在 Node.js 中使用 Axios,替代了 request;浏览器中还是使用 Fetch API,还没有在浏览器中尝试使用 Axios。...Ava, Chai.js, Jest, Enzyme, Headless Chrome – 测试框架,runner,断言库,单元测试,组件测试,端对端测试的一些工具。...我用 Ava 替代了 Mocha 用来做测试框架和 Runner,Headless Chrome 替代了 PhantomJS 做端对端测试,断言主要用 Chai 里面的 expect 以及 jsonschema...REST 有一种明日黄花的感觉,虽然还在用,但是感觉早晚被 GraphQL 等取代,毕竟我们真的越来越不关心数据是如何获取的,而应该关注在 store 如何设计上,专注在领域分析上面。...都是即可运行在浏览器环境,也可以运行在 Node.js 环境。 MongoDb/MySQL/Nginx/Redis – 这些都是常用的服务器应用。

    2.6K10

    【译】73个超棒且可提高生产力的 NPM 包

    它可以在每个平台,浏览器或其他设备上运行,并同时关注可靠性和速度。 16.WS[37] 简单易用,快速且经过全面测试的 WebSocket 客户端和服务器实现。...配置模块 24.Config[45] 设置存储在应用程序中的配置文件中,可以由环境变量、命令行参数或外部源覆盖和扩展。...46.Mocha[69] Mocha 是一个 JavaScript 测试框架,使得异步测试简单而有趣。...Mocha 测试是串行运行的,在将未捕获的异常映射到正确的测试用例的同时,允许进行灵活和准确的报告。 ?...在许多情况下这很有用,例如基于用户输入的任何自动化。 希望你找到了对你有用的有用 npm 包! 感谢你阅读,可以关注我[98]获取更多信息!

    5.9K30

    使用 Jest 进行前端单元测试

    Timer 业务代码中如果有 setTimeout 这样的计时器,在测试过程中如果真实的去执行,可能会严重拖慢整个测试项目的执行时间,设想一个功能有 n 个用例去测试,延时就会被重复 n 倍。...可以通过 react-test-renderer,把 React 组件生成快照并暂存下来,在之后跑用例时如果组件结果发生了改变则报错提醒。 例如下面做个简单的例子: ....在 Jest 中也不用像 mocha 那样通过执行 done 来通知异步结束,而是直接返回 Promise 和 async/await 就好。...我们都知道保持编写可测试的代码的习惯是非常重要的。可测试性差的代码,在写测试用例时也会花费成倍的时间。例如下面这个例子: ....另外因为在 fetch 的 promise 链上的连续操作,mock 时还要注意实现 response.json() 等操作。 这样的代码不仅显得比较长,单独一个测试用例的 mock 也很长。

    5.6K90
    领券