ebook img

Learning TypeScript PDF

352 Pages·2015·5.265 MB·english
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Learning TypeScript

Learning TypeScript Exploit the features of TypeScript to develop and maintain captivating web applications with ease Remo H. Jansen BIRMINGHAM - MUMBAI Learning TypeScript Copyright © 2015 Packt Publishing All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews. Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author, nor Packt Publishing, and its dealers and distributors will be held liable for any damages caused or alleged to be caused directly or indirectly by this book. Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information. First published: September 2015 Production reference: 1230915 Published by Packt Publishing Ltd. Livery Place 35 Livery Street Birmingham B3 2PB, UK. ISBN 978-1-78398-554-8 www.packtpub.com Table of Contents Preface ix Chapter 1: Introducing TypeScript 1 The TypeScript architecture 2 Design goals 2 TypeScript components 3 TypeScript language features 4 Types 7 Optional static type notation 7 Variables, basic types, and operators 8 Var, let, and const 10 Union types 10 Type guards 11 Type aliases 11 Ambient declarations 12 Arithmetic operators 13 Comparison operators 13 Logical operators 14 Bitwise operators 14 Assignment operators 15 Flow control statements 16 The single-selection structure (if) 16 The double-selection structure (if…else) 16 The inline ternary operator (?) 17 The multiple-selection structure (switch) 17 The expression is tested at the top of the loop (while) 19 The expression is tested at the bottom of the loop (do…while) 19 Iterate on each object's properties (for…in) 20 Counter controlled repetition (for) 20 Functions 21 Classes 22 Interfaces 24 Namespaces 25 [ i ] Table of Contents Putting everything together 26 Summary 27 Chapter 2: Automating Your Development Workflow 29 A modern development workflow 29 Prerequisites 30 Node.js 30 Atom 30 Git and GitHub 33 Source control tools 33 Package management tools 38 npm 38 Bower 41 tsd 42 Task runners 43 Checking the quality of the TypeScript code 45 Compiling the TypeScript code 46 Optimizing a TypeScript application 48 Managing the Gulp tasks' execution order 51 Test runners 53 Synchronized cross-device testing 55 Continuous Integration tools 58 Scaffolding tools 59 Summary 61 Chapter 3: Working with Functions 63 Working with functions in TypeScript 64 Function declarations and function expressions 64 Function types 65 Functions with optional parameters 66 Functions with default parameters 68 Functions with rest parameters 69 Function overloading 71 Specialized overloading signatures 72 Function scope 73 Immediately invoked functions 76 Generics 79 Tag functions and tagged templates 82 Asynchronous programming in TypeScript 83 Callbacks and higher-order functions 83 Arrow functions 84 Callback hell 86 [ ii ] Table of Contents Promises 90 Generators 96 Asynchronous functions – async and await 97 Summary 98 Chapter 4: Object-Oriented Programming with TypeScript 99 SOLID principles 100 Classes 101 Interfaces 104 Association, aggregation, and composition 105 Association 105 Aggregation 105 Composition 106 Inheritance 107 Mixins 109 Generic classes 115 Generic constraints 118 Multiple types in generic type constraints 122 The new operator in generic types 123 Applying the SOLID principles 123 The Liskov substitution principle 123 The interface segregation principle 125 The dependency inversion principle 126 Namespaces 127 Modules 129 ES6 modules – runtime and design time 131 External modules – design time only 132 AMD modules – runtime only 133 CommonJS modules – runtime only 134 UMD modules – runtime only 135 SystemJS modules – runtime only 136 Circular dependencies 136 Summary 138 Chapter 5: Runtime 139 The environment 140 The runtime 141 Frames 141 Stack 142 Queue 142 Heap 143 The event loop 143 [ iii ] Table of Contents The this operator 144 The this operator in the global context 144 The this operator in a function context 144 The call, apply, and bind methods 145 Prototypes 148 Instance properties versus class properties 149 Prototypal inheritance 152 The prototype chain 156 Accessing the prototype of an object 157 The new operator 158 Closures 158 Static variables with closures 160 Private members with closures 162 Summary 164 Chapter 6: Application Performance 165 Prerequisites 166 Performance and resources 166 Performance metrics 167 Availability 167 The response time 168 Processing speed 168 Latency 168 Bandwidth 168 Scalability 169 Performance analysis 169 Network performance analysis 169 Network performance and user experience 174 Network performance best practices and rules 176 GPU performance analysis 179 Frames per second (FPS) 179 CPU performance analysis 180 Memory performance analysis 183 The garbage collector 185 Performance automation 186 Performance optimization automation 187 Performance monitoring automation 187 Performance testing automation 188 Exception handling 189 The Error class 189 The try…catch statements and throw statements 190 Summary 191 [ iv ] Table of Contents Chapter 7: Application Testing 193 Software testing glossary 194 Assertions 194 Specs 195 Test cases 195 Suites 195 Spies 195 Dummies 195 Stubs 195 Mocks 196 Test coverage 196 Prerequisites 196 Gulp 197 Karma 197 Istanbul 197 Mocha 198 Chai 198 Sinon.JS 198 Type definitions 198 PhantomJS 199 Selenium and Nightwatch.js 199 Testing planning and methodologies 200 Test-driven development 200 Behavior-driven development (BDD) 201 Tests plans and test types 201 Setting up a test infrastructure 203 Building the application with Gulp 204 Running the unit test with Karma 207 Running E2E tests with Selenium and Nightwatch.js 210 Creating test assertions, specs, and suites with Mocha and Chai 213 Testing the asynchronous code 217 Asserting exceptions 218 TDD versus BDD with Mocha and Chai 219 Test spies and stubs with Sinon.JS 220 Spies 223 Stubs 225 Creating end-to-end tests with Nightwatch.js 227 Generating test coverage reports 228 Summary 230 [ v ] Table of Contents Chapter 8: Decorators 231 Prerequisites 231 Annotations and decorators 232 The class decorators 233 The method decorators 236 The property decorators 238 The parameter decorators 240 The decorator factory 242 Decorators with arguments 244 The reflection metadata API 245 Summary 249 Chapter 9: Application Architecture 251 The single-page application architecture 252 The MV* architecture 258 Common components and features in the MV* frameworks 259 Models 259 Collections 260 Item views 260 Collection views 261 Controllers 262 Events 263 Router and hash (#) navigation 263 Mediator 266 Dispatcher 267 Client-side rendering and Virtual DOM 268 User interface data binding 269 One-way data binding 269 Two-way data binding 270 Data flow 270 Web components and shadow DOM 272 Choosing an application framework 273 Writing an MVC framework from scratch 274 Prerequisites 276 Application events 277 Mediator 278 Application 281 Route 283 Event emitter 284 Router 285 Dispatcher 288 Controller 291 [ vi ] Table of Contents Model and model settings 292 View and view settings 295 Framework 299 Summary 299 Chapter 10: Putting Everything Together 301 Prerequisites 302 The application's requirements 302 The application's data 303 The application's architecture 304 The application's file structure 305 Configuring the automated build 307 The application's layout 310 Implementing the root component 310 Implementing the market controller 312 Implementing the NASDAQ model 314 Implementing the NYSE model 316 Implementing the market view 316 Implementing the market template 319 Implementing the symbol controller 320 Implementing the quote model 321 Implementing the symbol view 323 Implementing the chart model 325 Implementing the chart view 327 Testing the application 330 Preparing the application for a production release 330 Summary 332 Index 333 [ vii ] Preface Over the past few years, the JavaScript code base of an average web application has been exponentially growing. However, the current JavaScript specification (ECMAScript 5 or ES5) was designed several years ago and lacks some features that are necessary to cope with the complexity that we can find in large-scale JavaScript applications today. As a result of these missing features, maintainability problems have arisen. The upcoming JavaScript version (ECMAScript 6 or ES6) is meant to solve some of the maintainability issues of JavaScript, but its implementation is in progress and many incompatible web browsers are still in use today. For these reasons, the wide adoption of the ES6 specification is expected to be a slow process. Microsoft spent two years developing TypeScript with the goal of resolving the maintainability and scalability problems of JavaScript and publicly announced it in October 2012: "We designed TypeScript to meet the needs of the JavaScript programming teams that build and maintain large JavaScript programs. TypeScript helps programming teams to define interfaces between software components and to gain insight into the behavior of existing JavaScript libraries. TypeScript also enables teams to reduce naming conflicts by organizing their code into dynamically loadable modules. Typescript's optional type system enables JavaScript programmers to use highly-productive development tools and practices: static checking, symbol-based navigation, statement completion, and code re-factoring." - TypeScript Language Specification 1.0 [ ix ]

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.