Error.prototype.toString()
The toString()
method returns a string representing the
specified Error
object.
Syntax
js
toString()
Return value
A string representing the specified Error
object.
Description
The Error
object overrides the Object.prototype.toString()
method inherited by all objects. Its semantics are as follows:
js
Error.prototype.toString = function () {
if (
this === null ||
(typeof this !== "object" && typeof this !== "function")
) {
throw new TypeError();
}
let name = this.name;
name = name === undefined ? "Error" : `${name}`;
let msg = this.message;
msg = msg === undefined ? "" : `${msg}`;
if (name === "") {
return msg;
}
if (msg === "") {
return name;
}
return `${name}: ${msg}`;
};
Examples
Using toString()
js
const e1 = new Error("fatal error");
console.log(e1.toString()); // "Error: fatal error"
const e2 = new Error("fatal error");
e2.name = undefined;
console.log(e2.toString()); // "Error: fatal error"
const e3 = new Error("fatal error");
e3.name = "";
console.log(e3.toString()); // "fatal error"
const e4 = new Error("fatal error");
e4.name = "";
e4.message = undefined;
console.log(e4.toString()); // ""
const e5 = new Error("fatal error");
e5.name = "hello";
e5.message = undefined;
console.log(e5.toString()); // "hello"
Specifications
Specification |
---|
ECMAScript Language Specification # sec-error.prototype.tostring |
Browser compatibility
BCD tables only load in the browser
See also
- A polyfill of
Error.prototype.toString
with many bug fixes is available incore-js