原文地址:https://blogs.msdn.microsoft.com/typescript/2016/01/28/announcing-typescript-1-8-beta/

今天,我们发布了 TypeScript 1.8 Beta,伴随着 1.8 版本带来了大量的变化。欢迎使用并反馈给我们:send us your feedback. 可以从  Visual Studio 2015, NuGet (Compiler 和 MSBuild task), npm, 或者直接从 source 来获取它.

对于 NPM 用户,请使用下面的命令来获取。

> npm install -g typescript@beta

在 VS Code 中,可以下载上面的包,然后使用下面的提示更新 .vscode/settings.json 文件。

"typescript.tsdk": "/some/path/to/node_modules/typescript/lib"

JavaScript in TypeScript Compilation

在 TypeScript 1.8,TypeScript 编译器可以与 TypeScript 文件一起使用 JavaScript 文件。启用这个特性,仅仅需要添加一个编译选项 --allowJs ,或者在 tsconfig.json 配置文件的 compilerOptions 配置节中添加 “allowJS”: true。这是一个非常棒的特性:

转换 JavaScript 项目到 TypeScript 项目

对于大的项目来说,从 JavaScript 项目转换到 TypeScript 项目意味着风险。对于具体的项目来说,简单地将所有的 .js 文件转换为 .ts 文件会导致大量的编译错误。使得转换过程很不友好。现在,通过允许 TypeScript 编译合并编译 JavaScript 代码,就可以一次一个文件地转换,但是仍然允许编译整个项目。这就使得开发者可以完全掌控转换过程。

使用第三方的 JavaScript 库便可更加容易

为了在 TypeScript 项目中使用现有的 JavaScript 库,开发者不得不使用类型定义 (.d.ts ) 文件,以便 TypeScript 编译器在编译的时候知道你在做什么,而在运行时,是 JavaScript 引擎知道你在做什么。直到你需要打包你的外部脚本库,都没有问题。到打包这一步,开发者需要第三方的打包器,例如 webpack 或者 browserify 等等。使用 TypeScript 1.8,你只需要简单地在项目中包含第三方的 JavaScript 库,编译器将会处理它,包括 Source  Map!

琐碎的 JavaScript 处理

使用 JavaScript in TypeScript 编译,TypeScript 编译器可以使用同样的方式来处理 JavaScript 文件。这包括 ES3/ES5,不同类型的模块定义,以及打包。例如,对于使用 TypeScript 编译器进行 ES6 到 ES5 降级转换,你只需要使用下面的命令:

> tsc --allowJs --outDir out target_file.js

扩展的 JSX 支持

经过大量的讨论,TypeScript 1.8 带来了一些关键的改进来扩展 TSX/JSX 的支持。

定制的 JSX 工厂

伴随 React ,JSX 语法已经不仅仅用于 React。JSX 工厂允许重写默认的 React 工厂。伴随 --jsx react 使用新的编译标志 --reactNamespace <factory_name> ,TSX 的作者现在可以控制工厂的名称。

无状态功能组件

在 React 0.14 中,无状态的功能组件是一个新概念,已经被大量采用。从 TypeScript 1.8 开始,我们在 TSX 文件中支持无状态的功能组件。

interface GreeterProps {
name: string;
} class Greeter extends React.Component<GreeterProps, {}> {
render() {
return <div>Hello, {this.props.name}</div>;
}
} //stateless functional component SimpleGreeter
let SimpleGreeter = ({name = ‘world‘}) => <div>Hello, {name}</div>;

在 VS2015 中的语法高亮

伴随着 Visual Studio 中的 TypeScript 1.8 更新,JSX 现在可以获得代码分类和着色的改进。

TypeScript Nuget 包

长期以来,我们的一些用户要求提供官方的 TypeScript Nuget 包,从 1.8 Beta 开始,每个版本我们将会通过 Nuget 分发 TypeScript 编译器和 MSBuild 任务,包的链接如下:

TypeScript compiler

TypeScript MSBuild task

另外,我们还会在 MyGet 提供TypeScript 的每日构建。虽然不提供 build, 但是你可以方便获取,让我们知道你的想法。你可在这里找到 build:here.

Chakra Core + TypeScript

我们一直在努力提高 TypeScript 编译器的性能,在  Chakra Core 发布几周之后,我们对它进行了测试。下面是每个编译引擎对不同尺寸的代码进行编译的图表。我们发现  Chakra Core 有着重要的改进。对比上一个版本有 5-20% 的改进,对于 Node 有 10-50% 提高,基于上述原因,我们将在适当的时机切换到 ChakraCore.

还有更多

TypeScript 1.8 还包括许多特性,包括:F-Bounded polymorphism,字符串字面类型等等。如果你希望深入了解这些新特性,请查阅:what’s new page. 而且,我们一直鼓励浏览现有的问题,提交请求,或者直接到  gitter 与我们交流。

翻译: TypeScript 1.8 Beta 发布的更多相关文章

  1. TypeScript 1.5 Beta带来修饰元数据支持

    (此文章同时发表在本人微信公众号"dotNET每日精华文章") 今天由于有点小感冒,就不长篇大论了,简单介绍一下和VS 2015 RC一同发布的TypeScript 1.5 Bet ...

  2. 基于CKEditor 你能做很多App。CKEditor 4.5 and CKFinder 3 beta 发布

    直击现场 CKEditor 4.5 and CKFinder 3 beta 发布 oschina 发布于: 2015年04月10日 (0评) 分享到:    收藏 +5 4月18日 武汉 源创会开始报 ...

  3. 课堂Beta发布140字评论

    Beta发布140字评论: 第一组:飞天小女警 此项目组的功能是礼物挑选,创意十足,用户只要一听名字便会被深深吸引,并且页面设计感,时尚感十足,不断吸引客户的眼球,而且发布到云服务器上面. 第二组:金 ...

  4. 个人对beta发布的观点

    内容:五个小组的beta发布 时间:2016年11月10日 13:40-15:15 地点:传媒西楼202 发布顺序: 1.飞天小女警(选礼物) 2.金州勇士(在线考试) 3.新蜂(俄罗斯方块) 4.天 ...

  5. TypeScript 0.9.1 发布,新增 typeof 关键字

    TypeScript 0.9.1 发布了,该版本提升了编译器和语言的性能,增加新的语言特性 typeof ,更好的 this 处理等.详细介绍请看发行说明. TypeScript 是微软新推出的一种语 ...

  6. PyRedisAdmin v1.0 Beta 发布,Redis 在线管理工具 - 开源中国社区

    PyRedisAdmin v1.0 Beta 发布,Redis 在线管理工具 - 开源中国社区 PyRedisAdmin v1.0 Beta 发布,Redis 在线管理工具

  7. Alpha、伪Beta 发布后,夏一鸣的个人感想与体会

    伪Beta发布在4月15日拉开了帷幕,夏一鸣代表OneZero团队上台进行了Account的发布.产品发布成功,但依然存在问题和不足.以下就Alpha.伪Beta 发布谈一谈我自己(夏一鸣)的想法. ...

  8. Alpha、伪Beta 发布后,严一格的个人感想与体会

    伪Beta发布在4月15日下午2.30左右结束,严一格所在的“爆打”团队产品发布成功.下面是我的想法和体会~ 1.作为“爆打”团队中的一员,我对我们团队可以成功发布Alpha版本和伪Beta版本感到由 ...

  9. Beta发布 _thunder_文案+美工展示

    作业要求:https://edu.cnblogs.com/campus/nenu/SWE2017FALL/homework/1366 团队介绍:thunder 组成员及各位博客地址: 1.王航:htt ...

随机推荐

  1. 用Firefox的debugger来调试JavaScript

    1.自我感觉比firebug更好用 https://developer.mozilla.org/zh-CN/docs/Tools/Debugger

  2. uboot 链接地址与运行地址的区别

    对于ARM架构的CPU,上电后PC寄存器是指向0地址处的,从这个地址开始运行程序,那么运行了启动代码后会把程序搬移到内存中去运行,这样就是产生程序会在运行时有个两地址,而由源码编译为可执行文件时只会指 ...

  3. jQueryUI 之控件们

    总结:总的来说,这些控件可以在官网找到列子, 部分ui效果不如意的,可根据jQueryUI上添加的类选择器等,进行再加工 <!DOCTYPE html> <html> < ...

  4. 《Java中的自动装箱和拆箱功能.》

    //Java中的自动装箱和拆箱功能. class AutoboxingUnboxing { public static void main(String[] args) { //直接把一个基本类型变量 ...

  5. hdu 2059

    ps:终于解决了....卡了我好久.最后用了DP.然后还有记忆化搜索优化了一下.终于AC了 思路:要计算dp[n](就是到第n个站的最短时间,也就是最优方案),必须知道dp[0]到dp[n-1] 设j ...

  6. HDU 5360 (贪心)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5360 题意:告诉你n个区间[ l[i],r[i] ],然后让你排序,必须左区间不大于它前边的总区间个数 ...

  7. HDU 5234 DP背包

    题意:给一个n*m的矩阵,每个点是一个蛋糕的的重量,然后小明只能向右,向下走,求在不超过K千克的情况下,小明最终能吃得最大重量的蛋糕. 思路:类似背包DP: 状态转移方程:dp[i][j][k]--- ...

  8. option对象概念

    一.基础理解: var e = document.getElementById("selectId");   e.options = new Option("文本&quo ...

  9. 更新EF,EF 报错

    在项目中,对一个视图进行了更新,增加了一个字段,然后需要更新EF访问,可是往往会报错, 查看映射关系发现EF将字段映射为主键,而视图没有进行ISNULL处理. 可以有两种处理方式: 1:修改视图对字段 ...

  10. 百度翻译&&金山词霸API

    #/usr/bin/env python3 #coding=utf8 """百度翻译api功能实现函数,本模块基于Python3.x实现,getTransResult(q ...