Класс 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();

Проверьте этот код на детской площадке.

Другие вопросы по тегам