TypeScript学习笔记(一)环境搭建和数据类型
一、学习TypeScript的缘由
当前编写前端的逻辑的主流语言仍是JavaScript
,但这个语言由于其弱类型的特性使得它在很多的方面给程序员带来了许多的困扰,例如在使用IDE
时,IDE
往往难以推断出变量的类型,无法提供代码补全和错误提示,此外JavaScript
对面向对象的支持也比较弱,算是一种比较非常勉强的实现方式,这也导致使用JavaScript
编写项目时到后期变得难以维护等等。因此学习TypeScript
是非常有必要,也是符合未来前端的发展趋势的。
二、学习环境的搭建
1. TypeScript的编译环境
使用以下指令进行安装(需要有node.js环境):
npm install -g typescript
然后输入下面的指令可查看当前的版本:
> tsc -v
Version 4.3.5
2. vscode自动编译的配置
我使用的学习环境是 vscode
,先创建一个项目文件夹,然后输入(先cd到该文件夹中):
tsc --init
然后系统会给我们生成一个 tsconfig.json
的文件。
然后我们只需要将它的 outDir
的值设置为 "./js"
即可:
然后我们先新建一个index.ts
的文件,先编写一小段ts
代码:
let str: string = "你好ts"
let str1: string = "你好str1"
然后点击:终端 》 运行任务 》typescript 》tsc监视 即可
这样我们每次保存 ts
代码时,它就会被自动编译成 js
代码了。
编译出的 js
代码:
"use strict";
var str = "你好ts";
var str1 = "你好str1";
当然,除此之外我们也可以使用以下指令手动编译 ts
文件:
tsc xxx.ts
三、TypeScript中的数据类型
- 布尔类型
boolean
- 数字类型
number
- 字符串类型
string
- 数组类型
array
- 元祖类型
tuple
- 枚举类型
enum
- 任意类型
any
null
和undefined
void
类型never
类型
tips: 在TypeScript中定义变量时必须为变量表明变量的类型
1. 简单变量的定义和初始化
这里以 boolean
和 number
为例:
var flag: boolean = true
var a: number = 123
而当我们试图把一个其他类型赋值给一个数字类型的变量时会报错,例如:
2. 复杂变量的定义和初始化
数组类型
写法一:
let 数组变量名: 元素变量类型[] = [xxx, ...]
例如:
let arr: number[] = [1,2,3]
这种方式和Java
的写法非常类似。
写法二:
let 数组变量名: Array<> = [xxx, ...]
例如:
let arr2: Array<string> = ["123","haha"];
写法三:
let 数组变量名: any[] = [xxx, ...]
这样数组就退化为了 js
中的可以装载任意类型元素的数组了。
元组类型
在TypeScript
中元组类型属于数组的一种,可以指定每个元素的类型:
let 元组变量名:[类型一, 类型二, 类型三...]=[类型一变量, 类型二变量, 类型三变量...]
具体例子:
let oneTuple:[string, number, boolean] = ["ts",15.2,false];
枚举类型
语法:
enum 枚举类型名 {
变量1 [=xxx],
变量2 [=xxx]...
}
例如:
enum Flag {
SUCCESS = 1,
ERROR = -1
}
若不为枚举变量赋值,则它的默认值为索引值(从1开始)
enum Color {
RED, BLUE, GREEN
}
let computerColor: Color = Color.BLUE
console.log(computerColor);
运行结果:
3. 其他变量类型
任意类型
任意类型和es5
中没有指定类型相似,即一个变量可以使用任意的类型进行赋值。
语法:
let 变量名: any = 任意类型值;
示例:
let foo: any = 123;
foo = "hello world";
foo = false;
undefined类型
当一个变量声明而没有初始化赋值时,它的类型为undefined
。
我们可以使用一个多类型运算符 |
来表示一个变量可以有多个类型:
let num: number|undefined;
console.log("num=",num);
void类型
一般用于标明方法没有返回值,用法同 Java
和 c++
等的 void
:
function run(): void {
console.log("hello world");
}
TypeScript学习笔记(一)环境搭建和数据类型的更多相关文章
- Android Studio 学习笔记(一)环境搭建、文件目录等相关说明
Android Studio 学习笔记(一)环境搭建.文件目录等相关说明 引入 对APP开发而言,Android和iOS是两大主流开发平台,其中区别在于 Android用java语言,用Android ...
- 我的Java学习笔记 -开发环境搭建
开始学习Java~ 一.Java简介 Java编程语言是一种简单.面向对象.分布式.解释型.健壮安全.与系统无关.可移植.高性能.多线程和动态的语言. Java分为三个体系: JavaSE(J2SE) ...
- Django学习笔记 开发环境搭建
为什么使用django?1.支持快速开发:用python开发:数据库ORM系统,并不需要我们手动地构造SQL语句,而是用python的对象访问数据库,能够提升开发效率.2.大量内置应用:后台管理系统a ...
- cocos2d-x lua 学习笔记(1) -- 环境搭建
Cocos2d-x 3.0以上版本的环境搭建和之前的Cocos2d-x 2.0 版差异较大的,同时从Cocos2d-x 3.0项目打包成apk安卓应用文件,搭建安卓环境的步骤有点繁琐,但搭建一次之后, ...
- SpringData JPA的学习笔记之环境搭建
一.环境搭建 1.加入jar包 spring jar+jpa jar +springData jar >>SpringData jar包 2.配置applicationCont ...
- Mybatis学习笔记之---环境搭建与入门
Mybatis环境搭建与入门 (一)环境搭建 (1)第一步:创建maven工程并导入jar包 <dependencies> <dependency> <groupId&g ...
- 前端框架vue学习笔记:环境搭建
兼容性 不兼容IE8以下 Vue Devtools 能够更好的对界面进行审查和调试 环境搭建 1.nodejs(新版本的集成了npm)[npm是node包管理 node package manager ...
- Web安全测试学习笔记 - vulhub环境搭建
Vulhub和DVWA一样,也是开源漏洞靶场,地址:https://github.com/vulhub/vulhub 环境搭建过程如下: 1. 下载和安装Ubuntu 16.04镜像,镜像地址:htt ...
- 【Django学习笔记】-环境搭建
对于初学django新手,根据以下步骤可以快速进行Django环境搭建 虚拟环境创建 使用virtualenv创建并启用虚拟机环境 ,关于virtualenv可参考https://www.yuque. ...
- go 学习笔记之环境搭建
千里之行始于足下,开始 Go 语言学习之旅前,首先要搭建好本地开发环境,然后就可以放心大胆瞎折腾了. Go 的环境安装和其他语言安装没什么特别注意之处,下载安装包下一步下一步直到完成,可能唯一需要注意 ...
随机推荐
- B站英文教学视频的字幕获取 学习必看!
前言 最近在B站看一些纯英文的课程,视频课程有的是纯中文字幕的,有的是纯英文字幕的.由于英文的重要性,一份字幕的文档在我们观看后,留着日后粗略再读是很有益处的.但是为了得到这个英文字幕走了许多弯路.最 ...
- python 字典和列表嵌套用法
python中字典和列表的使用,在数据处理中应该是最常用的,这两个熟练后基本可以应付大部分场景了.不过网上的基础教程只告诉你列表.字典是什么,如何使用,很少做组合说明. 刚好工作中采集promethe ...
- Go语言中底层数组和切片的关系以及数组扩容规则
Go语言中底层数组和切片的关系以及数组扩容规则 demo package main import ( "fmt" ) func main() { // 声明一个底层数组,长度为10 ...
- 9、ssh服务详解及优化
ssh是"secure shell protocol"的简写,在进行数据传输之前,ssh先对练级数据包通过加密技术进行加密处理, 加密后再进行数据的传输,从而确保了数据的安全: s ...
- vue3,后台管理列表页面各组件之间的状态关系
技术栈 vite2 vue 3.0.5 vue-router 4.0.6 vue-data-state 0.1.1 element-plus 1.0.2-beta.39 前情回顾 表单控件 查询控件 ...
- 界面设计ie8 笔记
1.ie8 jsp中设置 margin:0 auto 无效 解决方法 在html 标签改为<!DOCTYPE html> 2.ie8 input file 无法通过js触发点击事件,网上 ...
- 如何跟领导解释为什么选择SpringCloud alibaba作为微服务开发框架
什么是微服务 提到微服务不得不提Martin Fowler在2014年3月25日发表的文章 Microservices,里面给出了微服务的定义.后续国内所有关于微服务的介绍都是基于这篇文章的翻译,或加 ...
- php图片木马实现原理
什么是木马 木马病毒是指隐藏在正常程序中的一段具有特殊功能的恶意代码,是具备破坏和删除文件.发送密码.记录键盘和攻击Dos等特殊功能的后门程序. 那,php的木马是长什么样的呢?我们来看下面这段代码: ...
- redis学习笔记(一)——windows下redis的安装与配置
前言 很久没有写东西了(.......我的水平就是记个笔记),北漂实习的我,每天晚上回来都不想动,但是做为社会主义接班人的我,还是要时刻给自己充充电,趁着年轻,趁着日渐脱发的脑袋还没有成为" ...
- mybatis框架的第二天
一.mybatis的基础crud的操作 先在接口中,写对应的方法名称,返回类型,访问符. 之后在映射配置文件中,写具体的实现 二.mybati中crud的细节 1.模糊查询 这是接口中 这是xml中 ...