博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
5分钟上手TypeScript踩坑
阅读量:6433 次
发布时间:2019-06-23

本文共 3667 字,大约阅读时间需要 12 分钟。

前言

最近在学习TypeScript,发现TypeScript的官方文档中的5分钟上手TypeScript辅导教程中会有许多新手可能很难理解的地方,所以记录一下

声明一下我用的版本是

npm install typescript@2.9.2 -g

以后版本可能有所不同

什么是TypeScript

维基百科上说 “TypeScript是一种由微软开发的自由和开源的编程语言。它是JavaScript的一个严格超集,并添加了可选的静态类型和基于类的面向对象编程。”

从名字上我们就可以看出 TypeScript 和 JavaScript 不同的地方就是type,因为 TypeScript 相较于 JavaScript 多了类型检查这一功能,都知道 JavaScript 是一门动态类型、静态作用域的语言,而 TypeScript 的更像变成了一门静态类型的语言

如何运行TypeScript

浏览器只能运行js、html、css语言,那ts要如何运行在浏览器上呢,我们要记住

浏览器可以运行js
浏览器不能运行ts
要把ts变成js才可以在浏览器上运行
tsc会把ts转化成js

那tsc是什么,如何获取呢,需要我们学会使用npm,然后安装

npm install -g typescript

就可以得到tsc和ts-node这两个命令了

构建第一个TypesScript文件

在五分钟上手TypeScript的文档中,要求我们将以下代码输入到greeter.ts文件里

function greeter(person) {    return "Hello, " + person;}let user = "Jane User";document.body.innerHTML = greeter(user);

因为上面我们说过浏览器不能运行ts,而document.body.innerHTML又需要我们在浏览器上运行,所以我们需要先把ts文件转化成js文件,这样会比较麻烦,所以下面我都建议改成用console.log

function greeter(person) {    return "Hello, " + person;}let user = "Jane User";console.log(greeter(user));

然后

ts-node greeter.ts

可以在终端中直接打出输出结果

类型注解

在上面的代码中,我们还看不出ts和js的区别,下面对上面的代码进行一个改变

function greeter(person: string) {    return "Hello, " + person;}let user = "Jane User";console.log(greeter(user));

在参数后加个冒号然后加个类型,这样就相当于给参数加上的了一层禁锢,当你输入的参数并不是字符串类型的时候

function greeter(person: string) {    return "Hello, " + person;}let user = 123;console.log(greeter(user));

进行编译转化成js的时候就会报错,如下

greeter.ts(7,21): error TS2345: Argument of type 'number' is not assignable to parameter of type 'string'.

这样子你发现错误的时机就从运行到浏览器上阶段提前到了编译阶段

另外值得一提的是如果,参数是undefined,那么类型检查并不会报错,例如

function greeter(person: string) {  return "Hello, " + person;}let user = undefined;console.log(greeter(user));

运行之后会正确输出

Hello, undefined

接口

学过 java 或者 c# 的人可能会很熟悉这个,就是相当于规定了一个对象一定需要包含几个属性,例如官方文档所给的例子,如果我们的对象不符合规则少写一个属性

interface Person {    firstName: string;    lastName: string;}function greeter(person: Person) {    return "Hello, " + person.firstName + " " + person.lastName;}let user = { firstName: "Jane"};console.log(greeter(user));

就会报错

greeter.ts(12,21): error TS2345: Argument of type '{ firstName: string; }' is not assignable to parameter of type 'Person'.
Property 'lastName' is missing in type '{ firstName: string; }'.

但如果我们多写了属性

interface Person {  firstName: string;  lastName: string;}function greeter(person: Person) {  return "Hello, " + person.firstName + " " + person.lastName;}let user = { firstName: "Jane", lastName: "User" , m:'ss'};console.log(greeter(user));

它仍然是可以正常运行的

TypeScript 的类的创建有点像 ES6 但是多了一个 public 的关键词,熟悉 java 的同学可能会知道,但是在ts中这个public的具体是什么作用,在官方文档给的例子中可以看出

class Student {    fullName: string;    constructor(public firstName, public middleInitial, public lastName) {        this.fullName = firstName + " " + middleInitial + " " + lastName;    }}interface Person {    firstName: string;    lastName: string;}function greeter(person : Person) {    return "Hello, " + person.firstName + " " + person.lastName;}let user = new Student("Jane", "M.", "User");console.log(greeter(user));

实际上就相当于

class Student {  fullName: string;  firstName: string;  middleInitial: string;  lastName: string;  constructor(firstName, middleInitial, lastName) {    this.firstName = firstName    this.middleInitial = middleInitial    this.lastName = lastName    this.fullName = firstName + " " + middleInitial + " " + lastName;  }}interface Person {  firstName: string;  lastName: string;}function greeter(person: Person) {  return "Hello, " + person.firstName + " " + person.lastName;}let user = new Student("Jane", "M.", "User");console.log(greeter(user));

后记

以上就是对5分钟上手TypeScript的解读,我也在继续学习当中,ts相较与js更加严格,可以在js运行之前发现错误,代码更不容易出现bug,看得出来是js从动态类型向静态类型的一种转变,但是上面我写的时候也发现,undefined类型并没有检查出来,所以可能还在不停完善中,但是不得不承认TypeScript开发会更舒服

转载地址:http://qexga.baihongyu.com/

你可能感兴趣的文章
支付宝推出基于区块链跨境支付,巨头入场小企业将面临灭顶之灾
查看>>
从事互联网行业,怎样才能快速掌握一门编程语言呢?
查看>>
React native 第三方组件 React native swiper
查看>>
接口幂等设计
查看>>
编程入门指南
查看>>
移动端的自适应方案—REM
查看>>
你真的懂volatile吗
查看>>
Android 编译时注解-提升
查看>>
说说 Spring AOP 中 @Aspect 的高级用法
查看>>
Workbox CLI中文版
查看>>
贝聊亿级数据库分库分表实践
查看>>
同时连接gitlab和github
查看>>
vuex源码分析
查看>>
tornado+datatables分页
查看>>
集成 Kubernetes 与 Cloud Foundry,IBM自有一套
查看>>
php 中英文字符分割
查看>>
No module named yum
查看>>
Shell处理用户输入参数----getopts
查看>>
【函数】06、装饰器的应用
查看>>
v$sysstat
查看>>