首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
V2EX  ›  JavaScript

js 的 try catch 可以重写吗?

  •  
  •   MuscleOf2016 · 104 天前 · 1980 次点击
    这是一个创建于 104 天前的主题,其中的信息可能已经有所发展或是发生改变。

    需要在项目所有 trycatch 中加个日志收集。

    19 回复  |  直到 2019-08-02 12:39:18 +08:00
        1
    newghost   104 天前
    js 是一般不写 try/catch,一般采用 error first,error 永远是回调的第一个参数,有 error 就用 console.log/ console.error 输出,只要把 console 重写到文件里就行。
        2
    MuscleOf2016   104 天前
    @newghost 是的,不过像我现在遇到的情况有什么好的解决办法尼,代码已经没办法改了,准备用工具去遍历注入的。用正则?
        3
    whileFalse   104 天前
    不知道 Error 类能不能加私货。
        4
    cctv1005s927   104 天前
    @newghost 不一定吧..从 async / await 出来之后.. try catch 就用得很多了..
        5
    Xxss   104 天前 via Android
    try {
    // ...
    } catch (e) {
    // ...
    } finally {
    // record log here
    }

    试试加一个 finally 块?
        6
    maichael   104 天前
    如果不换 try-catch 的写法的话,没办法。

    我的做法是所有 catch 都有一个 console.error,然后重写 console.error。
        7
    lymanliu   104 天前
    写个 webpack 插件,编译的时候注入,就好了吧
        8
    sunzongzheng   104 天前
    browser: window.onerror = function(message, source, lineno, colno, error) { ... }
    nodejs: process.on('uncaughtException', function(err) {
    console.error('Error caught in uncaughtException event:', err);
    })
        9
    MuscleOf2016   104 天前
    @sunzongzheng catch 的异常都处理过了,会走 onerror?
        10
    sunzongzheng   104 天前
    @MuscleOf2016 #9 不会
        11
    imlinhanchao   104 天前   ♥ 1
    code.replace(/(\}\s*catch\(\s*(\w+)\s*\)\s*{)/mg, "$1\nlogfuntion($2);\n");
        12
    Torpedo   104 天前
    你需要一个 babel 插件
        13
    MuscleOf2016   104 天前
    @Torpedo 哪个有推荐不
        14
    Torpedo   104 天前
    @newghost 怎么就不写 try catch 了? err first 只是一种风格,用 async await 不就要写 try catch 了?
    而且本身程序必然有错误捕获的模块,难道不用 try catch ?
        15
    Torpedo   104 天前   ♥ 1
    @MuscleOf2016 搜下,或者自己写个。https://github.com/darkyndy/babel-plugin-auto-logger
    我觉得你还是代码里分哪些是异常,哪些是错误 。设计下结构。统一捕获一下
        16
    otakustay   104 天前   ♥ 1
    @newghost first error 是 callback 的模式,同步不用 callback 肯定是 try/catch,异步 js 玩 Promise 多好多年了也还是 try/catch ……

    要重写是不可能的,上 babel 搞定还是比较容易的
        17
    nigelvon   104 天前   ♥ 1
    整个项目查找替换一下,catch 里面执行上报的方法,也就 1 分钟的事儿。
        18
    mystorp   104 天前 via Android   ♥ 1
    jscodeshift ?原理就是遍历 ast,查找 try catch。并加上自己的 log 代码。楼上说的 babel 插件也是类似的原理。不过,我觉得 17 楼的回答也很有意义,看怎么选择了
        19
    jifengg   102 天前 via Android
    catch 中是用什么记录异常的,如果是 console.error,那就重写它。评估一下不要对现有系统有影响就行。

    可别说 catch 里面连打印异常都没有。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   4117 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 27ms · UTC 03:20 · PVG 11:20 · LAX 19:20 · JFK 22:20
    ♥ Do have faith in what you're doing.