出于某种原因,在以下代码段中似乎无法使用构造函数委托:
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以及您的assert工作。
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()是创建的行号,而不是throwe发生的行号。但是,这可能比具有NotImplementedError.prototype.name = "NotImplementedError"影响Error对象的线的副作用更好。
throwe
NotImplementedError.prototype.name = "NotImplementedError"
另外,请注意NotImplementedError2,当我没有.name明确设置时,它等于“错误”。但是,如评论中所述,因为该版本将原型设置为newError(),所以我可以进行设置NotImplementedError2.prototype.name ="NotImplementedError2"并确定。
NotImplementedError2
.name
newError()
NotImplementedError2.prototype.name ="NotImplementedError2"