由于某种原因,构造函数委托在以下代码段中似乎不起作用:
function NotImplementedError() { Error.apply(this, arguments); } NotImplementedError.prototype = new Error(); var nie = new NotImplementedError("some message"); console.log("The message is: '"+nie.message+"'")
运行这个给出The message is: ''. 关于为什么,或者是否有更好的方法来创建新Error子类的任何想法?我不知道apply的本机构造函数是否存在问题?Error
The message is: ''
Error
apply
更新您的代码以将您的原型分配给 Error.prototype 和 instanceof 和您的断言工作。
function NotImplementedError(message = "") { this.name = "NotImplementedError"; this.message = message; } NotImplementedError.prototype = Error.prototype;
但是,我只会抛出您自己的对象并检查 name 属性。
throw {name : "NotImplementedError", message : "too lazy to implement"};
根据评论编辑
在查看了评论并试图记住为什么我会分配原型Error.prototype而不是new Error()像 Nicholas Zakas 在他的文章中所做的那样,我使用以下代码创建了一个jsFiddle:
Error.prototype
new Error()
function NotImplementedError(message = "") { this.name = "NotImplementedError"; this.message = message; } NotImplementedError.prototype = Error.prototype; function NotImplementedError2(message = "") { this.message = message; } NotImplementedError2.prototype = new Error(); try { var e = new NotImplementedError("NotImplementedError message"); throw e; } catch (ex1) { console.log(ex1.stack); console.log("ex1 instanceof NotImplementedError = " + (ex1 instanceof NotImplementedError)); console.log("ex1 instanceof Error = " + (ex1 instanceof Error)); console.log("ex1.name = " + ex1.name); console.log("ex1.message = " + ex1.message); } try { var e = new NotImplementedError2("NotImplementedError2 message"); throw e; } catch (ex1) { console.log(ex1.stack); console.log("ex1 instanceof NotImplementedError2 = " + (ex1 instanceof NotImplementedError2)); console.log("ex1 instanceof Error = " + (ex1 instanceof Error)); console.log("ex1.name = " + ex1.name); console.log("ex1.message = " + ex1.message); }
控制台输出是这样的。
undefined ex1 instanceof NotImplementedError = true ex1 instanceof Error = true ex1.name = NotImplementedError ex1.message = NotImplementedError message Error at window.onload (http://fiddle.jshell.net/MwMEJ/show/:29:34) ex1 instanceof NotImplementedError2 = true ex1 instanceof Error = true ex1.name = Error ex1.message = NotImplementedError2 message
这证实了我遇到的“问题”是错误的堆栈属性new Error()是创建的行号,而不是throw e发生的位置。NotImplementedError.prototype.name = "NotImplementedError"但是,这可能比影响 Error 对象的线条的副作用更好。
throw e
NotImplementedError.prototype.name = "NotImplementedError"
另外,请注意NotImplementedError2,当我没有.name明确设置时,它等于“错误”。但是,正如评论中提到的那样,因为该版本将原型设置为new Error(),所以我可以设置NotImplementedError2.prototype.name = "NotImplementedError2"并没问题。
NotImplementedError2
.name
NotImplementedError2.prototype.name = "NotImplementedError2"