上一节,我简单介绍了Typescript,并将Typescript和JavaScript进行了对比,有些网友提出了一些疑问,可能有些网友对于这个Typescript还不是特别的熟悉,这节,我做一些演示。

1.安装Typescript

Google Search Typescript,找到Typescript的下载安装包,我这次下载的0.9.0.1版本,安装图片:

安装过程非常迅速,一分钟搞定。

2.测试看是否安装成功,打开命令窗口(win+R),输入cmd ,命令窗口打开,输入tsc,你会看到相关的Typescript命令行,表明已经安装成功了。有些命令还是挺有用的

tsc -v 查看版本号

tsc C:\aa.ts D:\bb.js 将C盘下的aa.ts 编译并生成JavaScript file输出到D盘,名字为bb.js

tsc C:\typescripts\*.ts D:\all.js 这个就更有用了对不对?对Typescript合并输出一个js file

...

有些大家自己试试就知道了。。

3.用visual studio 演示下Typescript

新建一个工程

可以看到系统默认提供了相应的文件,将app.ts 里面内容全部删除掉,我们自己写一个

上图我简单介绍下几个关键字:

module:类似Java package 或者C# namespace的概念,一个module里面的任何变量的声明不会对另外一个module产生影响,那么尤其在做大型web项目,这个实在是太重要了。

export:类似任何面向对象语言里面的public,表明这个是个共有方法。

上图中,更有意思的是,我声明了两个private变量,智能提示对于我们的书写,提高了效率。我们继续

我们看到这个图片中,有红色的波浪线,而且有错误提示说,不能把string赋值给数值类型,这就是所谓的编译器,可以把我们的一大部分错误给屏蔽掉,提升我们的代码质量和效率,试想在弱类型的JavaScript中,var a=0 和var a=“0”,谁能告诉我哪个对哪个错误??在这样的代码存在很久之后,又有谁能告诉我,a到底是返回数值,还是返回字符串。

我们在写JavaScript的时候,还经常会遇到该变量名字或者方法名字的时候,在Visual studio中,可以简单做到这一步(上图演示),我觉得其他的IDE也应该支持这个,毕竟Typescript是开源的。但是这个我并没有测试,sorry。

下面我在对比下,ts 和js file的代码量,大家都懂得,无论是代码的层次结构,还是代码量上面,谁有更明显的优势呢?

我就把这个demo做完吧。其实我就是结单写了个计数器,下面是html启动页面的代码:

大家看到了么?这里面没有包含任何Typescript的文件,Typescript在整个application中,充当的是语法糖的角色,其实就是一名很靠得住的翻译。

启动,点击button按钮,计数器不断累加,程序非常简单,勿喷,但是这些足以说明Typescript的强大之处,谢谢微软。

上次我的博文,有些人问我,凭什么我说它是Teamwork的利器?

我们的计算机语言,由以前的面向过程的语言,慢慢的演变现在非常流行的OOP,基本上可以说,现在的主流语言都已经支持面向对象(Java,C++,C#等等),JavaScript是一门挺古老的语言,但是到现在也是盛行不衰,尤其现在Html5的流行,但是它本身有致命的弱点,就是弱类型,而且它没有package,class,interface,extends,generics等概念,导致它实现不了面向对象那些优势,但是Typescript的出现,终于把这些问题解决了,Typescript把面向对象的种种概念统统都支持了,对于尤其喜欢面向对象语言编程的大牛们,Typescript是个非常不错的选择。

之所以叫Teamwork,说明每个人对这个Team都有贡献,当然也有影响,代码质量的提高,除了自己的code经验,另外更重要的的一点就是工具,有些繁琐难做,而且容易导致错误的功能,为什么不选择交给机器呢?如果我们的code coverage100%,UnitTest 100% pass,那么我的质量得有多高啊?首现前提,自己的代码要让机器认识,是不是?如果code在编译阶段都出不了warning or error,那么你会把 Tester给累死的。这里说多了,我会选择个合适的时间讲下 CI 和 CD。如何提升Team的效率。

Typescript 团队合作的利器

为什么选择Typescript的更多相关文章

  1. Angular为什么选择TypeScript?

    原文地址:https://vsavkin.com/writing-angular-2-in-typescript-1fa77c78d8e8 本文转自:http://www.chinacion.cn/a ...

  2. 使用Visual Studio Code搭建TypeScript开发环境

    使用Visual Studio Code搭建TypeScript开发环境 1.TypeScript是干什么的 ? TypeScript是由微软Anders Hejlsberg(安德斯·海尔斯伯格,也是 ...

  3. Typescript 团队合作的利器

    前言 在介绍Typescript 之前,我需要隆重介绍一个人: 安德斯·海尔斯伯格(Anders Hejlsberg,1960.12~),丹麦人,Turbo Pascal编译器的主要作者,Delphi ...

  4. TypeScript开发环境搭建(Visual studio code)

    使用Visual Studio Code搭建TypeScript开发环境 1.TypeScript是干什么的 ? TypeScript是由微软Anders Hejlsberg(安德斯·海尔斯伯格,也是 ...

  5. 初步学习TypeScript

    使用Visual Studio Code搭建TypeScript开发环境 1.TypeScript是干什么的 ? TypeScript是由微软Anders Hejlsberg(安德斯·海尔斯伯格,也是 ...

  6. Ionic2系列——Ionic 2 Guide 官方文档中文版

    最近一直没更新博客,业余时间都在翻译Ionic2的文档.之前本来是想写一个入门,后来觉得干脆把官方文档翻译一下算了,因为官方文档就是最好的入门教程.后来越翻译越觉得这个事情确实比较费精力,不知道什么时 ...

  7. Ionic 2 Guide

    Ionic 2 Guide 最近一直没更新博客,业余时间都在翻译Ionic2的文档.之前本来是想写一个入门,后来觉得干脆把官方文档翻译一下算了,因为官方文档就是最好的入门教程.后来越翻译越觉得这个事情 ...

  8. 如何在vue中使用ts

    注意:此文并不是把vue改为全部替换为ts,而是可以在原来的项目中植入ts文件,目前只是实践阶段,向ts转化过程中的过渡. ts有什么用? 类型检查.直接编译到原生js.引入新的语法糖 为什么用ts? ...

  9. 智能可视化搭建系统 Atom 服务架构演变

    作者:凹凸曼 - Manjiz Atom 是什么?Atom 是集结业内各色资深电商行业设计师,提供一站式专业智能页面和小程序设计服务的平台.经过 2 年紧凑迭代,项目越来越庞大,需求不断变更优化,内部 ...

随机推荐

  1. 《More Effective C++》 条款5 谨慎定义类型转换函数

    ---恢复内容开始--- C++编译器能够在两种数据类型之间进行隐式转换(implicit conversions),它继承了C语言的转换方法,例如允许把char隐式转换为int和从short隐式转换 ...

  2. BZOJ1609: [Usaco2008 Feb]Eating Together麻烦的聚餐

    1609: [Usaco2008 Feb]Eating Together麻烦的聚餐 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 938  Solved ...

  3. app.config应该放哪?

    一:做了一个简单的三层构架的小例子,在主项目里调用工具类的方法实现在数据库里添加一条信息.先看下错误的提示信息是什么样的,如下图一,图二是调用工具类.直接在工具类里写上连接字符串就没问题,如果写到ap ...

  4. css3图片墙

    css相关知识: 1. 使用box-shadow设置图片阴影,为照片加上阴影 eg: box-shadow: 0 0 5px 3px #abc 2. 使用tansform-origin定义变形原点 e ...

  5. Qt 与 JavaScript 通信

    使用QWebView加载网页后,解决Qt与JavaScript通信的问题: The QtWebKit Bridge :http://qt-project.org/doc/qt-4.8/qtwebkit ...

  6. 《A First Course in Probability》-chaper7-极限定理-强大数定理

    在现实问题中我们对于一个实验往往会重复成千上万次,那么我们就需要关注在实验次数趋于无穷之后,整个实验的期望会趋于怎样一个结果.其实这一章“极限定理”都是在处理这个问题. 强大数定理: 这里的证明过程给 ...

  7. C++Primer第5版学习笔记(三)

    C++Primer第5版学习笔记(三) 第四/五章的重难点内容           你可以点击这里回顾第三章内容       因为第五章的内容比较少,因此和第四章的笔记内容合并.       第四章是 ...

  8. 安卓系统运行Debian-7.0环境(Debian for android)

    新手使用说明(下载地址在文章末尾): 〇.警告:root 有风险,折腾 Linux 更有风险,因使用 Debian for Armel 导致任何直接或间接的损失,本人不负任何责任:一.将 debian ...

  9. poj 1050 To the Max (简单dp)

    题目链接:http://poj.org/problem?id=1050 #include<cstdio> #include<cstring> #include<iostr ...

  10. MySQL 面试基础

    相关:http://blog.csdn.net/u013252072/article/details/52912385          http://blog.csdn.net/zhangliang ...