一、类(Class)

类是ts的核心,使用ts开发时,大部分代码都是写在类里面。

1、类的声明

多个对象有相同的属性和方法,但是状态不同。

声明类的属性和方法时可以加 访问控制符,作用是:类的属性和方法是否可以在类的外部访问到。

默认public,还可以取值private,protected。

对应prototype

2、类的构造函数

构造函数是类的特殊方法,只有在类被实例化的时候调用,而且只被调用一次。

构造函数名:constructor,不能在外部被访问。

作用:实例化一个人的时候必须指定名字。

class Person{
name;
constructor(name:string) {
console.log("haha");
}
eat() {
console.log("i am eating");
}
} var p1 = new Person("batman");
p1.eat(); var p2 = new Person("superman");
p2.eat();

简写如下,非常常用:注意简写时候constructor必须声明访问控制符。

class Person{
constructor(public name:string) {
}
eat() {
console.log(this.name);
}
} var p1 = new Person("batman");
p1.eat(); var p2 = new Person("superman");
p2.eat();

在构造函数时必须明确指定访问控制符。 constructor(public name:string)和 constructor(name:string)是不一样的。

3、类的继承

涉及到2个关键字

extends:用来声明类的继承关系

super:调用父类的构造函数或者方法

继承关系是一种是的关系。

extends关键字介绍:

class Person{
constructor(public name:string) {
}
eat() {
console.log(this.name);
}
} class Employee extends Person{
code: string;
work() { }
} var e1 = new Employee("name"); var p1 = new Person("batman");
p1.eat(); var p2 = new Person("superman");
p2.eat();

super关键字:

2个用法:

  • 调父类的构造函数
  • 调父类的其他方法

规定: 子类的构造函数必须调用父类的构造函数。

class Person{
constructor(public name: string) {
console.log(this.name+" haha");
}
eat() { }
} class Employee extends Person{
constructor(name: string, code: string) {
super(name);
this.code = code;
console.log(this.code + " xixi");
}
code: string;
work() { }
} var e1 = new Employee("name","1");

调父类的其他方法

class Person{
constructor(public name: string) {
console.log("haha");
}
eat() {
console.log("i am eating");
}
} class Employee extends Person{
constructor(name: string, code: string) {
super(name);
this.code = code;
console.log("xixi");
}
code: string;
work() {
super.eat();
this.doWork(); }
private doWork() {//私有方法
console.log("i am working");
}
} var e1 = new Employee("name","1");
e1.work();

二、范型generic

范型是一种参数化的类型,一般用来限制集合的内容。

约束传入类型,防止传入数据错误。

//数组的范型
var workers: Array<Person> =[];

三、接口

用来建立某种代码约定,使得其它开发者在调用某个方法或创建新的类时必须遵循接口所定义的代码约定。

两个关键字

interface声明接口

implements实现接口

2种使用方式:

用接口声明属性,接口作为方法的参数的类型声明

interface IPerson{
name: string;
age: number;
} class Person{
//接口作为方法的参数的类型声明
constructor(public config: IPerson) {
}
} var pa = new Person({
name: "zs",
age:18
});

用接口声明方法,类实现接口。主要是为了给泛型铺垫。

interface Animal{
eat();。
} class Sheep implements Animal{
eat() {
console.log("i eat grass");
}
}

所有声明实现这个接口的类必须实现这个方法。

四、模块Module

模块可以帮助开发者将代码分割为可重用的单元。开发者可以自己决定将模块中的哪些资源(类、方法、变量)暴露出去供外部使用,哪些资源只在模块内使用。

在ts中一个文件就是一个模块。

模块内部有export和import关键字。

export:模块对外暴露哪些资源。(prop,function,class)

import:需要别的模块为你提供什么。

五、注解 annotation

注解为程序的元素(类,方法,变量)加上更直观更明了的说明,这些说明信息与程序的业务逻辑无关,而是供指定的工具或框架使用的。

Angular 2中的Angular2框架提供的Component注解

AppComponent类上面有一个@Component注解,注解里有一些属性会告诉Angular2框架怎样来处理AppComponent类。

也可以注解在属性上,注解在方法上。

装饰器。https://blog.csdn.net/liwusen/article/details/86482476

看不懂的 建议可以参考后端框架spring 的一些内容。

六、类型定义文件

如何在ts中用jquery之类的第三方框架?

类型定义文件(*.d.ts):帮助开发者在TypeScript中使用已有的JavaScript的工具包,如:JQuery.

实际上就是一个TypeScript模块,一个ts文件,没什么特别的,把你要使用的avaScript的工具包里面的工具以TypeScript的类或者是模块的方式暴露出来供你在你的模块里去import。

ts中使用jquery:

jquery的类型定义文件就是jquery.d.ts拷贝到目录下即可。

或者通过 npm install --save @types/jquery 来安装类型定义文件。

工具:Typings专门用来安装类型定义文件的。

本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/6961783.html 有问题欢迎与我讨论,共同进步。

2017-06-08

TypeScript入门(三)面向对象特性的更多相关文章

  1. TypeScript入门三:TypeScript函数类型

    TypeScript函数类型 TypeScript函数的参数 TypeScript函数的this与箭头函数 TypeScript函数重载 一.TypeScript函数类型 在上一篇博客中已经对声明Ty ...

  2. 初识PHP(三)面向对象特性

    PHP5开始支持面向对象的编程方式.PHP的面向对象编程方法和别的语言区别不大,下面对PHP面向编程基本语法进行简单记录. 一.声明对象 声明方法: class Say{ public functio ...

  3. TypeScript入门五:TypeScript的接口

    TypeScript接口的基本使用 TypeScript函数类型接口 TypeScript可索引类型接口 TypeScript类类型接口 TypeScript接口与继承 一.TypeScript接口的 ...

  4. TypeScript -- 面向对象特性

    .class关键字和类名就可以定义一个类 . 类的访问控制符--有三个,.] = ] = ] = ;.声明参数 .用接口声明方法 .理解模块--一个文件就是一个模块,就是这么个意思 ,不用想的多么高大 ...

  5. TypeScript 学习四 面向对象的特性,泛型,接口,模块,类型定义文件*.d.ts

    1,面向对象的特性一:类,继承,见上一篇博客: 2,面向对象的特性二: 泛型(generic):参数化的类型,一般用来限制集合的内容:指定只能放某个类型的元素 如下图中的尖括号中的Person,就代表 ...

  6. C#面向对象的编程语言具三个特性

    C#面向对象的编程语言具三个特性:有封装性.继承性.多态性 .

  7. Python 入门 之 面向对象的三大特性(封装 / 继承 / 多态)

    Python 入门 之 面向对象的三大特性(封装 / 继承 / 多态) 1.面向对象的三大特性: (1)继承 ​ 继承是一种创建新类的方式,在Python中,新建的类可以继承一个或多个父类,父类又可以 ...

  8. php开发面试题---php面向对象详解(对象的主要三个特性)

    php开发面试题---php面向对象详解(对象的主要三个特性) 一.总结 一句话总结: 对象的行为:可以对 对象施加那些操作,开灯,关灯就是行为. 对象的形态:当施加那些方法是对象如何响应,颜色,尺寸 ...

  9. typescript 入门教程一

    ##### 从今天开始,持续更新typescript入门教程系列.... 目前ts越来越火,主流的前端框架,好比*angular,vue 3*均是采用ts来编写,所有很多公司的项目都是用**ts**来 ...

  10. TypeScript入门一:配置TS工作环境

    配置手动编译TS文件工作环境 配置webpack自动化打包编译工作环境(后面补充) 一.TypeScript入门学习引言 进入主题之前,首先说明这个系列的博客是我刚刚接触TypeScript的学习笔记 ...

随机推荐

  1. Python基于Flask框架配置依赖包信息的项目迁移部署小技巧

    一般在本机上完成基于Flask框架的代码编写后,如果有接口或者数据操作方面需求需要把代码部署到指定服务器上. 一般情况下,使用Flask框架开发者大多数都是选择Python虚拟环境来运行项目,不同的虚 ...

  2. linux分析apache日志获取最多访问的前10个IP

    apache日志分析可以获得很多有用的信息,现在来试试最基本的,获取最多访问的前10个IP地址及访问次数. 既然是统计,那么awk是必不可少的,好用而高效. 命令如下: awk '{a[$1] += ...

  3. URL末尾处的斜杠“/”

    在输入网址的时候,比如输入"http://www.xxx.com/",此URL中末尾的斜杠是至关重要的.因为在这种情况下,浏览器能安全的添加斜杠.而像"http://ww ...

  4. MySQL Crash Errcode: 28 - No space left on device

    一台MySQL服务器突然Crash了,检查进程 ps -ef | grep -i mysql 发现mysqld进程已经没有了, 检查错误日志时发现MySQL确实Crash了.具体如下所示: 注意日志中 ...

  5. NLP+语义分析(四)︱中文语义分析研究现状(CIPS2016、角色标注、篇章分析)

    摘录自:CIPS2016 中文信息处理报告<第二章 语义分析研究进展. 现状及趋势>P14 CIPS2016> 中文信息处理报告下载链接:http://cips-upload.bj. ...

  6. spring的Profile使用对比和应用场景分析

    spring中存在这样一个功能,通过Profile来选择不同环境下的不同配置,说白了,就是通过设置一个参数来选择使用不同的数据,这个数据可能是一个bean,可能是一个xml文件,也有可能是一个prop ...

  7. R︱Linux+Rstudio Server尝鲜笔记(打造最佳Rstudio体验+报错的解决方案)

    Rstudio Server 是Rstudio开发的基于R语言的网页版(只能在Linux),你在手机上都可以运行R,还是挺方便的.就是配置起来有点麻烦.      官方下载链接:https://www ...

  8. SystemVerilog语言简介(二)

    6. 用户定义的类型 Verilog不允许用户定义新的数据类型.SystemVerilog通过使用typedef提供了一种方法来定义新的数据类型,这一点与C语言类似.用户定义的类型可以与其它数据类型一 ...

  9. weblogic部署web项目出现错误

    1.错误描述 <2015-3-15 下午02时13分01秒 CST> <Info> <Security> <BEA-090905> <Disabl ...

  10. Flex报错之二

    1.错误描述 SecurityError: Error #2148: SWF 文件 file:///D:/Adobe Flash Builder 4 Installer/demo1/bin-debug ...