当使用对象文字

时间:2017-01-22 17:15:59

标签: javascript typescript

我有以下问题:我有一个类Foo,它会覆盖toString()的默认实现。

class Foo {
   bar: string;

   toString(): string {
      return this.bar;
   }
}

当我使用(类型化)对象文字初始化一个新变量并在这个新对象上调用toString()时,将调用标准的Javascript实现。这样“[object Object]”就会打印到控制台中。

let foo : Foo  = {
   bar: "baz"
}


console.log(foo.toString()) // does not invoke Foo.toString()

但是,当我使用new运算符创建对象时,一切都像魅力一样:

let foo: Foo = new Foo();
foo.bar = "baz"
console.log(foo.toString()); // prints out "baz"

我做错了什么?我想避免第二种选择,因为实际上Foo对象有许多(嵌套)属性。因此,它会导致非常详细的对象初始化。

1 个答案:

答案 0 :(得分:1)

你的第一个例子:

let foo : Foo  = {
   bar: "baz"
}

您正在创建一个对象文字并声称它具有与Foo相同的界面。它不是Foo的实际实例,因此它使用toString()的默认实现。

在你的第二个例子中:

let foo: Foo = new Foo();

您正在创建Foo的实际实例,其中已覆盖toString()