Класс Typescript использует интерфейс как тип вместо реализации
Я ищу способ имитировать C# способ использования / реализации интерфейсов. Короче я пытаюсь повторить следующий код:
interface EBook {
function read();
}
class EBookReader {
private $book;
function __construct(EBook $book) {
$this->book = $book;
}
function read() {
return $this->book->read();
}
}
class PDFBook implements EBook {
function read() {
return "reading a pdf book.";
}
}
class MobiBook implements EBook {
function read() {
return "reading a mobi book.";
}
}
Использование инструментов прекрасно работает, однако я не могу имитировать использование Class EBookReader Ebook как типа.
кодируйте с моим макетом кода: http://codepen.io/Ornhoj/pen/gLMELX?editors=0012
1 ответ
Решение
используя Ebook как тип
Дело чувствительное.
interface IEBook {
read();
}
class EBookReader {
book: IEBook;
constructor(book: IEBook) {
this.book = book;
}
read() {
this.book.read();
}
}
class PDFBook implements IEBook {
read() {
console.log("reading a pdf book.");
}
}
class MobiBook implements IEBook {
read() {
console.log("reading a mobi book.");
}
}
var pdf = new PDFBook();
var reader = new EBookReader(pdf);
reader.read();
Проверьте этот код на детской площадке.