как показать строку, которая вызвала ошибку в NodeJS?

#javascript #node.js #function #error-handling

Вопрос:

Рассмотрим мою ситуацию : я создаю пример модуля node js xyz.js . main.js это мой основной файл узла, например, вызывается функция xyz , и она вызвала ошибку из-за переданных недопустимых аргументов, теперь я хочу просто указать строку и номер строки main.js , которая вызвала ошибку.

Комментарии:

1. Что не так с собственным стеком ошибок?

2. Это работает, но не указывает точно место ошибки в одной строке. Это полезно, когда вы хотите получить полную информацию об ошибке, но не тогда, когда вы просто хотите осветить строку, из которой исходит ошибка

3. Я думаю, вы можете поймать ошибку, проанализировать стек, прочитать файл с fs помощью консоли и распечатать эту строку, однако я бы счел, что исходный стек в целом лучше использовать

4. стек указывает номер строки с помощью синтаксиса Object.<anonymous> ( file path) , и я решил эту проблему с помощью метода строки поиска. Хотя это и не идеальное решение, но временно оно решило мою проблему

Ответ №1:

 // main.js

const fs = require('fs')
const xyz = require('./xyz')

try {
    const values = xyz(1, 2) // missing 3rd parameter
    console.log(values)
} catch (e) {
    console.warn('Error:', e.message)
    e.stack
        .split('n')
        .slice(1)
        .map(r => r.match(/((?<file>.*):(?<line>d ):(?<pos>d ))/))
        .forEach(r => {
            if (r amp;amp; r.groups amp;amp; r.groups.file.substr(0, 8) !== 'internal') {
                const { file, line, pos } = r.groups
                const f = fs.readFileSync(file, 'utf8').split('n')
                console.warn('  ', file, 'at', line ':' pos)
                console.warn('    ', f[line-1].trim())
            }
        })
}
 
 // xyz.js

module.exports = (a, b, c) => {
    if (typeof a === 'undefined')
        throw new Error("Parameter A is not set")
    if (typeof b === 'undefined')
        throw new Error("Parameter B is not set")
    if (typeof c === 'undefined')
        throw new Error("Parameter C is not set")
    return { a, b, c }
}
 

Но, как я уже сказал, стек исходной ошибки имеет для меня больше смысла.