飞道的博客

TypeScript开启

421人阅读  评论(0)

TypeScript是什么?

typescript是以JavaScript为基础构建的语言,是一个Javascript的超集,可以在任何支持JavaScript的平台中执行,typescript扩展了JavaScript,并添加了类型。
注意:ts不能被js直接解析执行,需要经过编译为js执行类似于less这种预处理语言。

typescript增加了什么?

保持js原有类型的同时新增加了一些类型。
支持es的新特性。
添加了es不具备的新特性。
丰富的配置选项。

配置typescript开发环境:

1.下载安装node.js
2.使用npm全局安装typescript
进入命令行。
输入命令:npm i -g typescript
3.创建一个ts文件
4.使用tsc对ts文件进行编译。
进入命令行。
进入ts文件所在目录。
执行命令:tsc xxx.ts。
执行完上述操作之后会产生一个同名的js文件。

ts的基本类型

类型声明:

类型声明式ts非常重要的一个特点。通过类型声明可以指定ts中变量(参数、形参)的类型。
指定类型后,当为变量赋值时。ts编译器会自动检查是否符合类型声明,符合则赋值,否则报错。简而言之,类型声明给变量设置了类型,使得变量只能存储某种类型的值。
语法:


```typescript
let 变量:类型
let 变量:类型 = 值;
function fn(参数:类型,参数:类型):类型{
	...
}```

console.log('Hello Typescript');
//先声明后赋值
let a: number;   //a的类型设置为number,在以后的使用过程中a的值只能是数字
a = 10;
a = 33
// a = 'abc' // 此行代码会报错,因为变量a的类型是number,不能赋值字符串。

let b: string;
b = 'abc';
b = 'def';
// b = 1 //此行代码会报错,因为变量b的类型是string,不能赋值数字。



//声明完直接赋值
// let c: boolean = true;

//如果变量的声明和赋值时同时进行的,ts可以自动对变量进行类型检测,一旦赋值完成变量的类型就已经确定了。
let c = true;
c = false;


//js函数中的参数是不考虑类型和个数的
// function sum(a, b){
   
//   return a + b;
// }
// console.log(sum(123,456))  //579
// console.log(sum('123','456')) //'123456'


//ts中函数传参时可以规定参数的类型,函数返回值的类型,只是在编写代码的阶段会进行报错的提示,编译还是可以进行的。
function sum(a:number, b:number):number{
   
  return a + b;
}
console.log(sum(123,456))

 

自动类型判断:

ts拥有自动的类型判断机制。
当对变量的声明和赋值时同时进行的,TS编译器会自动判断变量的类型。
所以如果你的变量的声明和赋值时同时进行的,可以省略掉类型声明

类型:

类型 例子 描述
number 1,-33,2.5 任意数字
string “hi”,‘hi’,hi 任意字符串
boolean true、false 布尔值true或false
字面量 其本身 限制变量的值就是该字面量的值
any * 任意类型
unknow * 类型安全的any
void 空值(undefined) 没有值(或undefined)
object {name:‘齐天大圣’} 任意js对象
array [1,2,3] 任意js数组
tuple [4,5] ts新增类型,固定长度数组
enum enum{A,B} 枚举,ts中新增类型

这里在使用ts里的变量的时候,产生一个问题,同一个文件夹下(其实不同文件夹下也会产生这样的问题)的t不同s文件怎么会产生重名问题,是因为在一个没有任何设置的普通项目中,vscode编辑器会把当前打开的 ts 文件当作一个整体的作用域进行验证。解决办法是使用命令tsc init 去初始化ts工程,生成一个配置文件tsconfig.json。该文件内部主要有如下内容:
Created a new tsconfig.json with:

target: es2016
module: commonjs //采取文件模块,会在当前文件中创建一个本地作用域
strict: true
esModuleInterop: true
skipLibCheck: true
forceConsistentCasingInFileNames: true

类型使用实例如下:

//可以直接使用字面量来进行类型声明
let d: 10;

//可以使用 | 来连接多个类型(联合类型)
let e: 'male'| 'female';
e = 'female';
e = 'male';

let f: string | number;
f = 'abc';
f = 1

//any表示的是任意类型,当一个变量设置为any后相当于对该变量关闭了TS的类型检测。
//不建议使用any
//g的类型是any,它可以赋值给任意类型的变量
let g: any;  //显式any
// let g  //隐式any 即如果声明变量不指定类型,则ts解析器会自动判断变量的类型为any
g = 1;
g = 'abc';
g = true;

// unknown 表示未知类型的值  效果跟any是一样的
// unknow 实际上就是类型安全的any  该类型的变量不能直接赋值给其他变量
let h: unknown;
h = 1;
h = true;
h = 'abc';

let i:string;
// i = g;  //不报错
h = 'hello';
// i = h; //会报错  不能把uknow的值赋给h  
//改成这样则不会报错
// if(typeof h === 'string') {
   
//   i = h;
// }

// 类型断言 用来告诉解析器变量的实际类型
//语法:1.变量 as 类型
//      2.<类型>变量
i = h as string
i = <string> h

//void用来表示空,以函数为例,就表示没有返回值的函数
function fn():void {
   
  // return undefined;
  // return null;这两个返回值都为空。 或者只写或不写return都不会报错。
}

//never表示永远不会返回结果
function fn2():never {
   
  throw new Error("报错了");
}

//对象的类型声明
//object表示一个js对象  用的较少 js中一切皆对象 一般限制 我们是想限制对象里边包含有哪些属性
let j: object;
j = {
   };
j = function(){
   };
//{}用来指定对象中可以包含哪些属性
//语法:{属性名:属性值,属性名:属性值}
//在属性名后边加上?表示属性是可选的 否则必须包含这几个属性而且未指定的属性不能出现 否则会报错 
let k:{
   name: string,age?: 20};
k = {
   name: 'abc',age: 20}
//如果我们想要实现一个 一定包含name属性,其他属性随意的对象
// [propName:string]:any  表示任意类型的属性
let l:{
   name:string,[propName:string]:any}

l = {
   name:'zs',age:18,id:8888}


//这样写意义不大
// let m:Function;
//设置函数结构的类型声明
//语法:(形参:类型,形参:类型...)=>返回值
let m:(a:number,b:number)=>number
m = function(a1,a2){
   
  return a1 + a2
}

//数组的类型声明
//n:string[]表示一个字符串数组
let n:string[];

let o:number[]; //这个表示数值数组

let p:Array<string> //也表示字符型数组


// 元组:元组就是固定长度的数组
//语法:[类型,类型,类型]
let q:[string,number];
q = ['abc',123];

//enum枚举
enum Gender{
   
  male,
  female
}
let r: {
   name:string,sex:Gender}
r = {
   name:'LiHua',sex:Gender.male}

console.log(r.sex === Gender.male)


//&表示同时
let s:{
   name:string} & {
   age:number};  //s必须满足这两个对象


//类型的别名
type myType = string  //给string类型起个别名为mytype,但这样用没有意义,所以在下列情况,我们使用类型别名来简化代码
type myType1 = 1 | 2 | 3 | 4 | 5
let t: myType1;
let u: myType1;


 

TS编译选项

(1)tsc xxx.ts -w
这里的w是watch的意思,输入这样的命令之后,会帮助我们监视该ts文件,当该文件内容发生变化之后,会帮助我们在一定的时间间隔之后自动编译ts文件。
(2)ts配置文件
tsconfig.json是js编译器的配置文件,ts编译器可以根据它的信息对ts文件进行编译。

{
   
// include用来指定哪些ts文件需要编译
  // exclude用来指定哪些ts文件不需要编译
  // **表示任意目录   *表示任意文件
  "include": [
    "./**/*"
  ],
  "exclude": [
    //默认值
    // "node_modules","bowser_components","jspm_packages"
  ],
  "extends": "./xxx.json", //定义被继承的配置文件
  "files": [] ,// 要编译哪些文件直接罗列出来即可
  "compilerOptions": {
   
  	"strict": false, //所有严格检查的总开关 所有严格检查可以在这里统一控制 
  	"target": "ES5",   //编译后的js版本
  	"module": "ES2015",  //编译后的模块化规范
    "lib": [], //指定项目中使用的库
	"outDir": "./dist",
	"ourFile":"",  //将代码合并为一个文件
	"allowJs": false, //是否对js文件进行编译 默认不编译
	"checkJs": true,  //是否检查js代码语法符合规范
    "removeComments": false, //是否移除注释
    "noEmit": false, //不生成编译后的文件
    "noEmitOnError": false,  //当有错误时,不生成编译文件
    "alwaysStrict": false,  //用来设置编译后的代码是否使用严格模式
    "noImplicitAny": true, //不允许隐式的any类型
    "noImplicitThis": true, //不允许不明确类型的this
    "strictNullChecks": true, //严格的检查空值
  },


 }

 

转载:https://blog.csdn.net/m0_62962469/article/details/127414309
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场