TypeScript

开源公司:微软公司

作品详情

外文名
TypeScript
展开
开发公司
微软
展开
首版发布
2012年十月份
展开
类型
编程语言
展开
正式版发布
2013年6月19日[1]
展开
性质
JavaScript的一个超集
展开

1工具概况

TypeScript是一种由微软开发的自由和开源的编程语言。它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程。安德斯·海尔斯伯格,C#的首席架构师,已工作于TypeScript的开发。[2][3][4]

TypeScript扩展了JavaScript的语法,所以任何现有的JavaScript程序可以运行在在TypeScript环境中。TypeScript是为大型应用的开发而设计,并且可以编译为JavaScript。

TypeScript 支持为已存在的 JavaScript 库添加类型信息的头文件,扩展了它对于流行的库如jQuery,MongoDB,Node.js和 D3.js 的好处。

2背景

TypeScript 起源于开发应用程序规模的 JavaScript 应用程序的需求。Microsoft的语言开发者们说内部以及外部的客户都表示他们构建 JavaScript 代码的问题。

很多最终依赖于 JavaScript 的开发者通常用编译为 JavaScript 代码的另一种语言写脚本,例如CoffeeScript和 Script# (读作 ScriptSharp)。一个明显的劣势是也许无法从那另一种语言使用任何 JavaScript 的具体的语言特性,如果那种语言不支持它的话。

在 Microsoft 内部,它导致了自定义工具以简化 JavaScript 组件的编写的需求。

3特性

TypeScript 是一种给 JavaScript 添加特性的语言扩展。

● 类型批注和编译时类型检查

●类

●接口

●模块

●lambda 函数

语法上,TypeScript 很类似于JScript .NET,另外一个添加了对静态类型,经典的面向对象语言特性如类,继承,接口和命名空间等的支持的 Microsoft 对 ECMA-262 语言标准的实现。

类型批注

TypeScript 通过类型批注提供静态类型以在编译时启动类型检查。这是可选的,而且可以被忽略而使用 JavaScript 常规的动态类型。

对于基本类型的批注是 number, bool 和 string。而弱或动态类型的结构则是 any 类型。

类型批注可以被导出到一个单独的声明文件以让使用类型的已被编译为 JavaScript 的 TypeScript 脚本的类型信息可用。批注可以为一个现有的 JavaScript 库声明,就像已经为 Node.js 和 jQuery 所做的那样。

当类型没有给出时,TypeScript 编译器利用类型推断以推断类型。如果由于缺乏声明,没有类型可以被推断出,那么它就会默认为是动态的 any 类型。

声明文件

当一个 TypeScript 脚本被编译时,有一个产生作为编译后的 JavaScript 的组件的一个接口而起作用的声明文件 (具有扩展名 .d.ts) 的选项。在这个过程中编译器基本上带走所有的函数和方法体而仅保留所导出类型的批注。当第三方开发者从 TypeScript 中使用它时,由此产生的声明文件就可以被用于描述一个JavaScript库或模块导出的虚拟的 TypeScript 类型。

声明文件的概念类似于 C/C++中头文件的概念。

类型声明文件可以为已存在的 JavaScript 库手写,就像为 jQuery 和 Node.js 所做的那样。

对 ECMAScript 6 的支持

TypeScript 增加了对为即将到来的 ECMAScript 6 标准所建议的特性的支持。

如下为其构想:

类 (以及继承) 模块Arrow functions

尽管标准还未准备就绪,Microsoft 说它的目标是使 TypeScript 的特性与建议的标准看齐。

TypeScript 支持集成了可选的类型批注支持的ECMAScript6 的类。

泛型

这种语言的规范说明一个未来的版本将会支持基于类型擦除的泛型编程。

与 JavaScript 的兼容性

TypeScript 是 JavaScript 的一个超集。默认情况下编译器以 ECMAScript 3 (ES3) 为目标但 ES5 也是受支持的一个选项。一个 TypeScript 应用可以利用已存在的 JavaScript 脚本。编译后的 TypeScript 脚本也可以从 JavaScript 中使用。

现有框架如 jQuery 和 Node.js 等受到完全支持。这些库的类型声明在源代码中提供。

支持的浏览器和平台

运行于任何平台上的任何网页浏览器都可以运行 TypeScript 由于它仅仅是被编译为标准的 JavaScript。一个脚本既可以被预编译为 JavaScript 也可以通过为 TypeScript 包含 JavaScript 编译器实时编译。

4工具

编译器

TypeScript 编译器,名称叫 tsc, 是用可以被编译为可以被执行在任何 JavaScript 引擎中,在任何宿主 - 如浏览器 - 中的常规 JavaScript 的 TypeScript 写的。编译器包被绑定于一个可以执行编译器的脚本宿主。使用Node.js作为宿主的 Node.js 包同样可以获得。

也有用 JavaScript 写的客户端编译器的一个 alpha 版本,它在页面载入时,实时执行 JavaScript 代码。[5]

这种编译器的当前版本默认支持 ECMAScript 3。一个选项是允许以 ECMAScript 5 为目标以利用该版本独有的语言特性。类,尽管是 ECMAScript 6 标准的一部分,在这两个模式下都可用。

5支持

IDE 和编辑器支持

Microsoft为Visual Studio 2012和WebMatrix提供了一个插件,也为Sublime Text,Emacs和Vim提供了基本的文本编辑器支持。在线的Cloud9 IDE也支持 TypeScript。JetBrains也计划在他们的 IDE 系列中支持 TypeScript, 而且已经发行了具有部分支持的PhpStorm6 和WebStorm6 预览版本。

6开源

TypeScript 是开源的,其源代码可以在 Apache 2 License 下从CodePlex获得。这个项目由Microsoft维持,但是任何人可以通过经 CodePlex 项目页发送反馈,建议和 bugfixes 而做出贡献。[6]

已有一些批评提到这一想法,即使 TypeScript 鼓励强类型,当前也只有Microsoft Visual Studio允许为该语言容易的开发。最初的观点是在其它的编辑器上带来强类型,IntelliSense, , OSX 和 Windows,提供针对之前对提供此类服务的困难度的估计的 IntelliSense, 代码完成和句法高亮。

7发布

2013年6月19日,在经历了一个预览版之后微软正式发布了正式版TypeScript 0.9,向未来的TypeScript 1.0版迈进了很大一步。

TypeScript 0.9迎来了一些重大的新功能,除对语言本身特性进行了扩充之外,还更加完善地整合了Visual Studio,微软开发部副总裁Soma Somasegar发布帖子称,新版本的TypeScript在交互式性能方面有了显著的提高和改善。

与JavaScript相比,TypeScript[9]进步的地方包括:加入注释,让编译器理解所支持的对象和函数,编译器会移除注释,不会增加开销;增加一个完整的类结构,使之更像是传统的面向对象语言。[1]

8词条图册

声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态
案例
1. 该项目是本人从0到1搭建的微前端公共基础框架。 2. 该项目使用了 vue3.2 + vite + ts + pinia + qiankun.js 实现整体微前端体系的实现。 3. 该项目主容器使用了 Vue3.2 子容器可使用 Vue3.0或2.0以及其他 react ,原生 js 等去开发不同的模块,在主容器中引入即可 实 现项目的无缝衔接。 4. 该框架已使用到公司的部分项目中,目前运行正常,线上也并无出现框架方面的问题
1.基于原有框架,抽离出全局样式公共配置并进行注释,通过变量进行控制全局样式。达到可动态配置; 2. 负责编写业务模块内容,对公共样式进行封装,对复用公共组件进行抽离,约定项目目录工程化; 3. 封装按钮及路由人员权限方法,同后端人员进行沟通,定义相应的人员权限配置,通过指令对当前按钮进行权限码 比对,失败即删除; 4. 配合ui实现样式,高度还原界面,协商页面协调性,处理页面交互问题,并根据设计稿,完成分配的模块开发任务; 5. 配合后端人员,调试接口,处理接口数据类型,以及定义传递参数问题; 6. 对form表单进行校验,动态表单,封装过自定义校验数字功能,正则匹配; 7. 使用 echa
球秀后台管理系统, 主要用于管理 B端 和 C端的数据,可查看所有用户操作对小程序操作的痕迹 主要技术栈: vue3 + element-plus
2110vueUI组件库Vue 组件后台管理系统
亲子乐园项目 三个模块,使用微信小程序原生代码实现 包括登陆模块、育儿商城、个人中心 支持账号管理、隐私协议、和在线客服等功能
负责行记模块开发架构: 1. 首先对交互类型来源进行划分,如:文章、产品、公司,从而可以支持所有的评论、点赞、收藏、投诉等 2. 然后开发行记模块,划分类型。
1100旅游系统
当前共4813个项目

评论