Book Image

Switching to Angular - Third Edition

By : Minko Gechev
Book Image

Switching to Angular - Third Edition

By: Minko Gechev

Overview of this book

Align your work to stable APIs of Angular, version 5 and beyond, with Angular expert Minko Gechev. Angular is the modern Google framework for you to build high-performance, SEO-friendly, and robust web applications. Switching to Angular, Third Edition, shows you how you can align your current and future development with Google's long-term vision for Angular. Gechev shares his expert knowledge and community involvement to give you the clarity you need to confidently switch to Angular and stable APIs. Minko Gechev helps you get to grips with Angular with an overview of the framework, and understand the long-term building blocks of Google's web framework. Gechev then gives you the lowdown on TypeScript with a crash course, so you can take advantage of Angular in its native, statically typed environment. You'll next move on to see how to use Angular dependency injection, plus how Angular router and forms, and Angular pipes, are designed to work for your projects today and in the future. You'll be aligned with the vision and techniques of the one Angular, and be ready to start building quick and efficient Angular applications. You'll know how to take advantage of the latest Angular features and the core, stable APIs you can depend on. You'll be ready to confidently plan your future with the Angular framework.
Table of Contents (10 chapters)

Introducing structural typing

An important feature of the type system of TypeScript is that it's structurally typed. Formally this means that the types equivalence and compatibility are determined by the structure of the types, not by other characteristics such as name or inheritance hierarchy.

This may sound quite abstract at first, so let's take a look at a specific example:

// ch4/structural-typing/example.ts

interface Namable {
name: string;
}

class Cat {
name: string;
}

class Castle {
name: string;
capacity: string;
}

const formatName = (obj: Namable) => `The name is ${obj.name}`;

The preceding snippet defines an interface called Namable, which has a declaration of a single property called name. We also define the Cat and Castle classes: both of them having a name property but neither of them implementing the Namable interface.

If we invoke formatName with a new...