最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

ecmascript 6 - How to modify the message of a Javascript Error object? - Stack Overflow

programmeradmin0浏览0评论

Is there any harm in updating the message of an Error object like this?

const err = new Error('bar');
...
err.message = `foo ${err.message}`;

My objective is to add some useful information to the error message when logging the error.

Is there any harm in updating the message of an Error object like this?

const err = new Error('bar');
...
err.message = `foo ${err.message}`;

My objective is to add some useful information to the error message when logging the error.

Share Improve this question edited Jan 23, 2019 at 13:46 p7adams 6623 gold badges9 silver badges26 bronze badges asked Jan 23, 2019 at 13:38 JoeTideeJoeTidee 26.2k29 gold badges113 silver badges163 bronze badges
Add a ment  | 

2 Answers 2

Reset to default 2

It can be useful to add some extra information/breadcrumbs as an exception travels up through your application layers. That said, you are mutating an object, which can be hard to reason about in a large code-base; exceptions management normally being a cross-cutting concern in your application.

Also bear in mind that some libraries will extend the Error class and leave the message property without a setter, making it ready-only.

I just noticed some harm :-(

On chrome 127.0.6533.17 (but not firefox 127.0.2), after your code, the error object is in a screwy state, in which err.message contains your additional annotation, but printing err does not show it:

const err = new Error('bar');
err.message = `foo ${err.message}`;
console.log("err.message = ",err.message);  // "err.message =  foo bar"
console.log("err = ",err);  // "err =\nError: bar\n    at <anonymous>:1:13"

The above is from chrome. On firefox, it shows "foo bar" in the final message instead.

发布评论

评论列表(0)

  1. 暂无评论