JS和TS 的区别

JavaScript(简:js)和TypeScript(简:ts)都是用于编写web应用程序的语言,它们的区别在于:

1:类型不同

JS:一种脚本语言,用于创建动态网页、弱类型、没有静态类型选项

TS:ts是js的超集,用于解决大项项目的代码复杂性,强类型,支持静态和动态类型;ts包含了js的库和函数,ts可以写任何js,调用任何js的库,可以在ts中使用原生js语法;

2:数据类型不同

TS的数据类型有:布尔值、数字、字符串、数组、元组(tuple)、枚举(enum)、any、void、null和undefined、never、object、unknown、

never:是其它类型(包括 null 和 undefined)的子类型,代表从不会出现的值;

any和unknown的区别

相同:都可以赋任意类型的值,最终该变量的类型,由最后一个值类型决定

不同:any可以赋值给任意类型的变量,并将该变量的类型修改为any变量值的类型

          unknown 不可以,可以吧unknown 看做是安全的any

如果非要把unknow 赋值给其他类型 怎么办?

使用类型断言、或类型判断(通过 if typeof)

类型断言:变量as类型表示告诉ts 该变量的实际类型

js的数据类型有:string、number、boolean、null、undefined、object、array、function、symbol(es6中引入)

3:类型声明

TS 中的类型声明:指定类型后,当变量赋值时,ts编译器就会自动检查值是否符合声明类型、如果符合就赋值,不符合就报错;

JS 中的类型声明:变量类型声明并不是强制性的,因为JavaScript 是一种动态类型语言,变量的类型会在运行时自动确定;

4:编译

TS需要将代码编译为js代码才能在浏览器中执行

JS可以直接在浏览器中运行

5:TS 有类型断言

TS有类型断言 变量 as类型;可以直接告知该变量的实际类型

6:函数的不同

1:TS:需要对函数中形参进行类型声明

JS中函数定义参数,传参的时候,可以传递任意类型,不够严谨

2:js中当函数没有返回值的时候 默认返回值是 undefined

TS:第一种情况:不设置返回值类型,但是有返回值,这时候TS解析器会根据返回值的类型进行判断,返回值类型是什么 函数返回值类型就是什么

第二种情况:设置返回值类型,则return的值必须严格按照返回值类型进行返回

第三种情况:设置返回值类型为 void,void用来表示空,以函数为例,就表示没有返回值的函数,或返回值为空,如果想要一点返回值都没有,设置返回值类型为never(永远不会返回结果)

7:数组类型声明

js中,数组的元素,可以是任意类型,没有局限性

TS 中对数组类型声明之后就只能存放一种数据类型的数据,假如想创建一个能存储任意类型的数组(let e:Array<any>/let e:any[] ;)

第一种:let 变量名:类型名: [ ] ;

第二种:let 变量名:Array<类型名>;

8:TS中的枚举和JS中的对象不一样

枚举代表的是一系列特定类型的对象,这是从别的编程语言派生出来的概念,所以我们不能用js 的概念强加到它上面,其实枚举最好理解的就是一系列确定的常量。枚举中的属性,只能用来取值,不能重复赋值(只读属性)

9:创建对象的方式

JS的创建对象方式:

1:基于Object的方式创建对象;

2:对象字面量;

3:构造函数;

4:原型 prototype

5:class类

TS的创建对象方式:

1:通过字面量

2:通过Object

3:通过工厂模式创建

4:通过构造函数创建

5:通过class类创建

6:可以通过实现接口创建

7:通过继承抽象类创建

10:扩展特性

Js的语法,不支持把当前代码,编译为除当前语法外的其他版本

Ts支持把代码编译为ES3 ES4 ES5 ES6+ 等指定的语法规范

11:接口、继承、泛型

JavaScript是一种基于原型的语言,而不是传统的面向对象语言,不支持模块,不支持泛型或接口

TypeScript在JavaScript的基础上添加了类、接口、继承、泛型等面向对象编程的概念和特性、它允许模块化编程,可以把声明、数据、函数和类封装在模块中。使得代码组织和维护更加容易。

12:继承

TypeScript 支持类的继承,可以通过 extends 关键字指定一个类继承自另一个类。

而在 Javascript 中,除了es6,其他的语法规范,不支持使用extends 来继承。

13:访问修饰符

TypeScript 引入了额外的访问修饰符(如:piblic、private、protected)来控制类的成员访问范围,这增加了对类以及其他成员的访问权限控制。而在JavaScript中,类和类成员的访问权限是公共的。

14:可选的构造函数参数

在TypeScript 中,我们可以在构造函数参数上使用,表示可选参数。这是的我们可以定义构造函数参数的可选性。而在Javascript中,构造函数参数是必需的。

15:重载

js没有重载概念

ts有可以重载:重载指的是在同一个类中定义多个同名的方法,但它们的参数类型,参数个数或返回类型不同。通过重载,我们可以为同一个方法名创建多个具有不同参数的版本。

16:重写

ts增加了重写,子类覆盖了父类中的属性或是方法叫做重写 子类和父类同名的方法和属性,在子类中重新声明的时候,就覆盖了父类原本的内容

17:static 和 readonly

ts中增加了 static 和 readonly,而js中没有

static

(静态修饰符,被static修饰的属性或方法,属于类的。可以通过类名调用,不属于实例的,实例没办法使用 和 es6中的static一样)

readonly

(被readonly修饰的属性,只能读取不能修改)

  • 13
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值