Running TypeScript in the Web Browser
This page is an introduction to using TypeScript in a web browser.
Compiling and bundling
Here’s one way to run TypeScript inside a web page:
- compile the TypeScript code into JavaScript
- bundle all the
import
ed JavaScript files together into a single JavaScript file (often calledbundle.js
or something similar) - use a
<script>
tag to load the bundled JavaScript file into the web page
In the project setup, the first two steps are done by a tool called browserify
, in combination with the TypeScript compiler.
But because software development is very iterative – editing the TypeScript source, then running it, then editing it again, then running again, etc. – it is easier if the compiling and bundling happens automatically whenever you edit.
This can be done by an additional tool, watchify
.
To use this setup, start by running watchify
:
npm run watchify-example # if you are editing ExampleWindow.ts
npm run watchify-client # if you are editing StarbClient.ts
It will compile and bundle the code to produce a bundle in the dist/
folder (either example-bundle.js
or client-bundle.js
). If you look in example-window.html
and starb-client.html
, you will see a corresponding <script>
tag at the end, which loads the bundle into the web page.
So your next step is
You will see the web user interface in your browser, and the code that you compiled and bundled with npm run watchify-...
will be running in that web page.
Importantly, the npm run watchify-...
command keeps running.
It watches your TypeScript source files for changes.
Whenever you edit and save any .ts
file that ExampleWindow.ts
(or StarbClient.ts
) depended on, it will automatically recompile and rebundle.
So once you have started watchify
, and loaded the corresponding HTML file into your browser, your normal development cycle will be:
Viewing console output
When your TypeScript code is running in the web browser, debugging output appears in the developer console. Here’s how to open the developer console in common browsers:
- Chrome: View → Developer → JavaScript Console
- Firefox: Tools → Browser Tools → Web Developer Tools, then choose the Console tab in the developer pane that opens.
- Safari: Develop → Show JavaScript Console. (If you don’t see the Develop menu in the menubar, choose Safari → Preferences, click Advanced, then select “Show Develop menu in menu bar.”)