TypeScript之面向对象初体验
1、安装nodejs和vscode:
nodejs : https://nodejs.org/en/
Visual Studio Code : https://www.visualstudio.com/en-us/products/code-vs.aspx
安装是很简单的,一路next就行,此处不详细描述。
检验node是否安装成功,打开命令行,输入node -v, 显示如下图,说明安装成功。

PS: TypeScript毕竟是微软发明的,用微软的编辑器更省心,当然不是必须的,否则得根据你的编辑器找typescript插件,你懂的。
2、上面的步骤完成后,安装typescript,找开命令行,输入指令:npm install -g typescript

安装完成,命令行输入tsc -v进行检验,显示版本号说明安装成功,如下图

3、完成了typescript环境的配置,接下来我们可以开始写代码了。
新建一个文件夹demo, 在它下面创建oop.ts

oop.ts代码如下:
/**
* 声明抽象类Shape
* */
abstract class Shape {
//声明受保护的属性edge, 是的,你没看错,protected只能用于父类和子类
protected edge: number;
//声明构造函数,入参类型为number
constructor(edge: number) {
this.edge = edge;
}
//声明类实例方法,方法名后面的number是限制方法的返回类型
getEdge(): number {
return this.edge;
}
//声明抽象方法
abstract getArea(): number;
} /**
* 声明类Triangle, 继承自抽象类Shape,必须实现抽象方法getArea()
* */
class Triangle extends Shape {
//声明类私有属性,其他类不能访问,包括父类
private width: number;
private height: number; //声明构造函数,必须显式调用父类构造函数,用super()
constructor(width: number, height: number) {
super(3);
this.width = width;
this.height = height;
} //实例方法,重写父类同名方法
getArea(): number {
return this.width * this.height / 2;
}
} /**
* 声明类Rectangle, 继承自抽象类Shape,必须实现抽象方法getArea()
* */
class Rectangle extends Shape {
//声明类私有属性,其他类不能访问,包括父类
private width: number;
private height: number; //声明构造函数,必须显式调用父类构造函数,用super()
constructor(width: number, height: number) {
super(4);
this.width = width;
this.height = height;
} //实例方法,重写父类同名方法
getArea(): number {
return this.width * this.height;
}
} //模拟入参数类型限制为Shape抽象类实例
function outputShape(shape: Shape) {
console.log(shape.getEdge());
console.log(shape.getArea());
} //模拟程序主入口函数
function main() {
outputShape(new Triangle(4, 5));
outputShape(new Rectangle(4, 5));
} main();
4.选中oop.ts文件, 右键选择“在命令提示符中打开”

在命令行中,输入tsc oop.ts,执行后会在相同目录下生成oop.js文件

oop.js文件内容如下:
var __extends = (this && this.__extends) || function (d, b) {
for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p];
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
/**
* 声明抽象类Shape
* */
var Shape = (function () {
//声明构造函数,入参类型为number
function Shape(edge) {
this.edge = edge;
}
//声明类实例方法,方法名后面的number是限制方法的返回类型
Shape.prototype.getEdge = function () {
return this.edge;
};
return Shape;
}());
/**
* 声明类Triangle, 继承自抽象类Shape,必须实现抽象方法getArea()
* */
var Triangle = (function (_super) {
__extends(Triangle, _super);
//声明构造函数,必须显式调用父类构造函数,用super()
function Triangle(width, height) {
_super.call(this, 3);
this.width = width;
this.height = height;
}
//实例方法,重写父类同名方法
Triangle.prototype.getArea = function () {
return this.width * this.height / 2;
};
return Triangle;
}(Shape));
/**
* 声明类Rectangle, 继承自抽象类Shape,必须实现抽象方法getArea()
* */
var Rectangle = (function (_super) {
__extends(Rectangle, _super);
//声明构造函数,必须显式调用父类构造函数,用super()
function Rectangle(width, height) {
_super.call(this, 4);
this.width = width;
this.height = height;
}
//实例方法,重写父类同名方法
Rectangle.prototype.getArea = function () {
return this.width * this.height;
};
return Rectangle;
}(Shape));
//模拟入参数类型限制为Shape抽象类实例
function outputShape(shape) {
console.log(shape.getEdge());
console.log(shape.getArea());
}
//模拟程序主入口函数
function main() {
outputShape(new Triangle(4, 5));
outputShape(new Rectangle(4, 5));
}
main();
5.执行oop.js文件,校验结果是否正确,在命令行中输入node oop.js
输出如下内容,说明执行成功:

最后,可见TypeScript的语法已经很接近Java或C#了,而且它最主要的就是实现了编译时类型检查,还有类,抽象类,接口,泛型等OOP的实现, 这对Java或C#的开发者而言,学习成本一下就降低了。
看了上面的TypeScript语法,你会发现变量声明是这样的:edge : number, 为什么不搞成number edge呢?不然不是更象Java或C#了?
个人觉得原因可能是因为Dart,因为它就是这样声明变量的,如果TypeScript也这样实现的,语法上跟Dart太接近了,恐怕就得被谷歌告了吧。
PS: typescript只是个js预编译器,如果你想象Java或C#等静态语言一样写js代码,或许它是你不错的选择,否则你还是可以选CoffeeScript等其他js预编译器。
TypeScript之面向对象初体验的更多相关文章
- TypeScript札记:初体验
1.简介 TypeScript 是一种由微软开发的自由和开源的编程语言.它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程. TypeScript是一种 ...
- python_92_面向对象初体验
class dog: def __init__(self,name): self.name=name def bulk(self): print('%s汪汪汪!'%self.name) d1=dog( ...
- Scala 深入浅出实战经典 第66讲:Scala并发编程实战初体验
王家林亲授<DT大数据梦工厂>大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频.PPT.代码下载:百度云盘:http://pan.baidu.com/s/1c0noOt6 ...
- node.js 初体验
node.js 初体验 2011-10-31 22:56 by 聂微东, 174545 阅读, 118 评论, 收藏, 编辑 PS: ~ 此篇文章的进阶内容在为<Nodejs初阶之express ...
- PHP初体验
PHP初体验 提笔写初体验总不知道从何说起,直接聊PHP中的函数.PHP网络技术.数据库操作.PHP模板等感觉又不是初体验.最后还是决定从PHP的面向对象.PHP的魔术方法.PHP的反射.PHP中的异 ...
- junit4初体验
OK,现在我们正式开始junit4系列的整理.前面的junit38作为4的补充知道就好了,实际编码中我们以4为主.这里先来一把junit的初体验,同时也让我们来一步一步的了解下TDD的好处. ORM大 ...
- SSH初体验系列--Hibernate--2--crud操作
Ok,今天比较详细的学习一下hibernate的C(create).R(read).U(update).D(delete) 相关api... 前言 Session: 是Hibernate持久化操作的基 ...
- Linux内核驱动学习(三)字符型设备驱动之初体验
Linux字符型设备驱动之初体验 文章目录 Linux字符型设备驱动之初体验 前言 框架 字符型设备 程序实现 cdev kobj owner file_operations dev_t 设备注册过程 ...
- go语言的初体验
分享最近学习 Go 语言的心得和体会,适合有编程基础的人,因为这里只做经验性的总结概述,不做基础教学的入门知识讲解,如果想要学习编程语言的基础知识,请出门左转进入官方文档,查看基础教学文档. Go 概 ...
随机推荐
- redis成长之路——(一)
为什么使用redis Redis适合所有数据in-momory的场景,虽然Redis也提供持久化功能,但实际更多的是一个disk-backed的功能,跟传统意义上的持久化有比较大的差别,那么可能大家就 ...
- React Native 之 Text的使用
前言 学习本系列内容需要具备一定 HTML 开发基础,没有基础的朋友可以先转至 HTML快速入门(一) 学习 本人接触 React Native 时间并不是特别长,所以对其中的内容和性质了解可能会有所 ...
- .NET面试题系列[4] - C# 基础知识(2)
2 类型转换 面试出现频率:主要考察装箱和拆箱.对于有笔试题的场合也可能会考一些基本的类型转换是否合法. 重要程度:10/10 CLR最重要的特性之一就是类型安全性.在运行时,CLR总是知道一个对象是 ...
- 【开源】知乎日报UWP 更新
说明 大概十天之前我更新了一次APP,后来又仔细看了一下Store里的评论,发现还有几个地方没有改过来.于是前天晚上抽时间改了一下,顺便完善了一下UI体验. 没有看前面文章的童鞋可以看一下下面的链接: ...
- 小谈Scrum敏捷开发流程
一晃眼,有两年没有写博客了,回顾前两年,各种奔波,各种忙碌,也有不少的收获.从今天开始,我要把这些收获都分享在这里. 其实这两年,对我影响最大的是开发流程.总所周知,一个好的开发流程,对于项目的进行, ...
- React Native 环境搭建
1,安装 HomeBrew /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install ...
- idea报错:error java compilation failed internal java compiler error
idea下面报如下问题 error java compilation failed internal java compiler error 解决办法:Setting->Compiler-> ...
- Application Request Route实现IIS Server Farms集群负载详解
序言 随着公司业务的发展,后台业务就变的越来越多,然而服务器的故障又像月经一样,时不时的汹涌而至,让我们防不胜防.那么后台的高可用,以及服务器的处理能力就要做一个横向扩展的方案,以使后台业务持续的稳定 ...
- 【.NET深呼吸】应用上下文(AppContext)
在.net 4.6中新增了一个类,叫AppContext,这个家伙嘛,技术含量不算高,只不过是在编程的时候可以方便用用而已.应用上下文允许定义一个标识(用字符串表示),并且在应用程序运行期间可以切换状 ...
- MVVM下listbox默认显示最后一行
原文地址:http://stackoverflow.com/questions/16866309/listbox-scroll-into-view-with-mvvm public class Scr ...