Cover image credit: Daria Kraplak
Table of Contents
Introduction
Purpose of TypeScript
Comparing JavaScript and TypeScript
Conclusion
Introduction
Before diving into what TypeScript is, let’s talk about JavaScript first! Did you know that JavaScript was invented in 1995? I didn’t either.
During this time, it fulfilled the need of processing simple web pages in people’s browsers. Since 1999, JavaScript has been improved and can handle the fun and dynamic web pages we are building nowadays. In addition, it is a fairly easy-to-use programming language as it is flexible with (slight spoiler here) data types.
However, there was an issue that was not being addressed. Ironically, the reason why JavaScript is easy to use is the same reason why it can break our code. Here is where TypeScript can help us!
Purpose of TypeScript
TypeScript is a superset of JavaScript. What does this mean? Well, to some, TypeScript is not a programming language as it is utilized to assist with the pre-existing JavaScript code. Regardless, TypeScript helps us JavaScript users by reinforcing the structure of our code. This is done by ensuring the consistency in data types for each variable we have. This is beneficial when it comes to testing because it highlights potential bugs during development and warns us before the code is compiled into JavaScript.
Comparing JavaScript and TypeScript
They Share These Data Types
- string
- number
- boolean
- undefined
- null
However, their implementation requires a different approach. Let me show you how!
Inferences
When defining a variable in JavaScript, its data type can change later on if we want it to. This is a different story for TypeScript as a variable’s data type is either inferred by TypeScript or explicitly stated by us. A variable’s data type can become any if it cannot be inferred or it is not explicitly stated!
// JavaScript let x = 6; // x stores a number value. x = "Hello there"; // x is now storing a string value. // This is valid since JavaScript allows dynamic type reassignment. // TypeScript let x = 6; // x stores a number value. // (For line below) Error: Type string is not assignable to type number. x = "Hello there"; // The reassigned value below matches the inferred or declared type of // the variable. TypeScript is okay with this. x = 8; // For both // x stores a number value and does not allow reassignment here. const x = 20; // Error: Cannot assign to 'x' because it is a constant. x = 25;
Type Annotation
As a continuation of the subsection above, another way we can explicitly state a variable’s data type in TypeScript is by using type annotation. This means adding a colon and type (:
// JavaScript let x = 6; // x stores a number value. x = "Hello there"; // x is now storing a string value. // This is valid since JavaScript allows dynamic type reassignment. // TypeScript let x = 6; // x stores a number value. // (For line below) Error: Type string is not assignable to type number. x = "Hello there"; // The reassigned value below matches the inferred or declared type of // the variable. TypeScript is okay with this. x = 8; // For both // x stores a number value and does not allow reassignment here. const x = 20; // Error: Cannot assign to 'x' because it is a constant. x = 25;
Shapes
What does “shapes” mean in TypeScript? For example, when it comes to strings, their methods come with their own properties. These “properties” make up the “shape” or structure of the variable. To access a variable’s properties, we must first ensure that the method we are using provides the necessary information. JavaScript is not strict with this and allows variables to change their shapes when it comes to runtime. However, we have to be careful with TypeScript as it is searching for the exact properties of a variable. It is like fitting blocks into the outlines that match their shapes.
// JavaScript // No need to state the data type here, just assign the variable a value. let color = ‘purple’; // Since JavaScript is flexible, it is fine with this reassignment. color = ‘blue’; // This is also the case even if the value changes to 10. // TypeScript // 'color' is declared and expected to have a string value. let color: string; // Similar to the line above, except we assign a value as well. let color: string = 'red'; color = ‘purple’; // 'purple' is a string value, so this is valid. color = ‘blue’; // 'blue' is a string value, so this is valid.
There are plenty more than these!
Conclusion
These were my first impressions of TypeScript thus far. It is safe to say that I am fascinated by how it can elevate what JavaScript can do for us already. I am eager to learn more and implement it into my JavaScript projects!
I hope this has piqued your interest in adding TypeScript to your sandbox/toolbox alongside JavaScript. Who wouldn’t want their code to be better structured?
The above is the detailed content of Adding to the Script with TypeScript. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Java and JavaScript are different programming languages, each suitable for different application scenarios. Java is used for large enterprise and mobile application development, while JavaScript is mainly used for web page development.

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

The following points should be noted when processing dates and time in JavaScript: 1. There are many ways to create Date objects. It is recommended to use ISO format strings to ensure compatibility; 2. Get and set time information can be obtained and set methods, and note that the month starts from 0; 3. Manually formatting dates requires strings, and third-party libraries can also be used; 4. It is recommended to use libraries that support time zones, such as Luxon. Mastering these key points can effectively avoid common mistakes.

JavaScriptispreferredforwebdevelopment,whileJavaisbetterforlarge-scalebackendsystemsandAndroidapps.1)JavaScriptexcelsincreatinginteractivewebexperienceswithitsdynamicnatureandDOMmanipulation.2)Javaoffersstrongtypingandobject-orientedfeatures,idealfor

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScripthassevenfundamentaldatatypes:number,string,boolean,undefined,null,object,andsymbol.1)Numbersuseadouble-precisionformat,usefulforwidevaluerangesbutbecautiouswithfloating-pointarithmetic.2)Stringsareimmutable,useefficientconcatenationmethodsf

Event capture and bubble are two stages of event propagation in DOM. Capture is from the top layer to the target element, and bubble is from the target element to the top layer. 1. Event capture is implemented by setting the useCapture parameter of addEventListener to true; 2. Event bubble is the default behavior, useCapture is set to false or omitted; 3. Event propagation can be used to prevent event propagation; 4. Event bubbling supports event delegation to improve dynamic content processing efficiency; 5. Capture can be used to intercept events in advance, such as logging or error processing. Understanding these two phases helps to accurately control the timing and how JavaScript responds to user operations.

Java and JavaScript are different programming languages. 1.Java is a statically typed and compiled language, suitable for enterprise applications and large systems. 2. JavaScript is a dynamic type and interpreted language, mainly used for web interaction and front-end development.
