TypeScript基本知识(为学习AngularJS2框架做个小铺垫)

时间:2023-02-13 21:26:24

学习angularjs2框架,需要了解一些TypeScript知识点,基本了解下面这几个知识点学习AngularJS2 就够用了

1.TypeScript

1.1显示类型的定义

TypeScript类似于java和c++,允许我们显示声明的类型:

let foo : number = 42;

let 声明变量跟js里面定义var一样

1.2 any类型

TypeScript所有的类都是any的子类,如果把所有变量都声明为any类型,就是失去TypeScript编译器带来的优点,慎用any。

1.3 Enum类型

跟java里面的枚举类型一样

enum STATES {
CONNECTING,
CONNECTED,
DISCONNECTING,
WAITING,
DISCONNECTED
};

1.4 Array类型

TypeScript中的数组和JavaScript类似。

let randomItems: any[] = [];
randomItems.push(1);
randomItems.push("foo");
randomItems.push([]);
randomItems.push({});

1.5 Function类型

如果使用函数表达式的方式把一个函数赋值给一个变量,可以如下定义:

let variable:(arg1:type1,arg2:type2,...) = >returnType

例如:

let isPrime: (n:number) => boolean = n=>{
//body }

如果采用函数声明的方式

function isPrime(n:number): boolean{
//body
}

如果需要在对象字面量里面定义方法

let math = {
squareRoot(n:number):number{
  //body
}
}

如果我们定义的函数只会产生一些副作用,而不是返回一个值,那么我们可以把它定义成void函数:

let person = {
_name :null,
setName(name:string):void {
  this._name =name;
}
}

1.6 定义类

class Human {
static totalPeople = 0;
_name : string;
constructor(name){
    this._name = name;
    Human.totalPeople += 1;
}
get name(){
  return this._name;
}
set name (val) {
  this._name = val;
}
talk() {
  return 'hello ${this.name}';
}
}

可以如下调用

let human = new Human('foo');
console.log(human._name);

1.7 访问修饰符

public 全局可访问

private 当前类内部访问

portected 当前类内部或者子类中访问

1.8 定义接口

interface Accountable {
getIncome(): number;
}

实现这个接口

class Firm implements Accountable {
getIncome(): number{
  //body
}
}
class Individual implements Accountable {
getIncome(): number{
  //body
}
}

和java语法一样,如果实现了这个接口,那么必须实现这个接口的里面定义的所有方法。

1.9 接口继承

接口之间可以相互继承,并支持多继承

interface Accountable {
accountNumber: string;
getIncome():number;
}
interface Indivdual extends Accountable{
ssn: string;
}

1.10 使用TypeScript装饰器提升表现力

class Http{
//body
}
class GitHubApi{
constructor (@Inject(Http) http){
  //body
}
}

1.11 使用泛型函数

function identity<T>(arg:T){
return arg;
}

多重泛型

let pair = new Pair<string,number>();
pair.key = "foo";
pair.value = 42;

TypeScript基本知识(为学习AngularJS2框架做个小铺垫)的更多相关文章

  1. html&sol;css 盒子布局 Margin 、Padding 、border 以及 清除浮动的知识 (学习HTML过程中的小记录)

    html/css  盒子布局 Margin .Padding .border 以及 清除浮动的知识 (学习HTML过程中的小记录) 作者:王可利(Star·星星) width     是"宽 ...

  2. java基础知识再学习--集合框架-对象的强、软、弱和虚引用

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://zhangjunhd.blog.51cto.com/113473/53092 本文 ...

  3. 一点记忆—— Java框架知识的学习有感

    一点记忆—— Java框架知识的学习有感         说一下自己学习的框架知识的历程吧:好久了,应该是一年前,也就是大三上的时候,我对于基本的 Java编程就已经达到所谓的“熟练”,认为自己可以在 ...

  4. Django学习---Web框架及基础知识

    Django学习---Web框架 web框架的本质 我们在学socket,我们创建一个socketserver,然后运行起来,有一个client客户端要连接socket服务端,连接上之后,如果两边都没 ...

  5. 人工智能范畴及深度学习主流框架,IBM Watson认知计算领域IntelligentBehavior介绍

    人工智能范畴及深度学习主流框架,IBM Watson认知计算领域IntelligentBehavior介绍 工业机器人,家用机器人这些只是人工智能的一个细分应用而已.图像识别,语音识别,推荐算法,NL ...

  6. 深入浅出学习Hibernate框架(一):从实例入手初识Hibernate框架

    这篇博客是hibernate学习的第一篇,主要简介hibernate框架,之后简单说一下hibernate的文件夹结构,最后写一个简单的hibernate实例.通过这三步来简单的认识一下hiberna ...

  7. 深入浅出学习Hibernate框架(二):JDBC基础操作

    上篇博客<深入浅出学习Hibernate框架(一):从实例入手初识Hibernate框架>简单介绍了一下Hibernate框架,并且举了一个实例来了解Hibernate.这篇博客将介绍JD ...

  8. 人工智能范畴及深度学习主流框架,谷歌 TensorFlow,IBM Watson认知计算领域IntelligentBehavior介绍

    人工智能范畴及深度学习主流框架,谷歌 TensorFlow,IBM Watson认知计算领域IntelligentBehavior介绍 ================================ ...

  9. (&ast;)(转)要快速学习SSM框架,你需要一套学习曲线平滑的教程

    作者:meepo链接:https://www.zhihu.com/question/57719761/answer/156952139来源:知乎著作权归作者所有.商业转载请联系作者获得授权,非商业转载 ...

随机推荐

  1. &lbrack;转载&rsqb;memcached完全剖析--1&period; memcached的基础

    转载自:http://charlee.li/memcached-001.html 翻译一篇技术评论社的文章,是讲memcached的连载.fcicq同学说这个东西很有用,希望大家喜欢. 发表日:200 ...

  2. Golang基础语法1

    打开cmd命令窗口 保存,编译,执行: 1.保存到一个×××.go的文件(我这里保存到  E:\GoTest\hello.go   下) 2.编译,在命令提示符中执行命令: go build -o E ...

  3. dubbo框架原理

    Dubbo提供了三个关键功能:基于接口的远程调用,容错与负载均衡,服务自动注册与发现. Dubbo使得调用远程服务就像调用本地java服务一样简单. https://www.jianshu.com/p ...

  4. 最大似然估计实例 &vert; Fitting a Model by Maximum Likelihood &lpar;MLE&rpar;

    参考:Fitting a Model by Maximum Likelihood 最大似然估计是用于估计模型参数的,首先我们必须选定一个模型,然后比对有给定的数据集,然后构建一个联合概率函数,因为给定 ...

  5. javascript使用事件委托

    事件委托是javascript中一个很重要的概念,其基本思路就是利用了事件冒泡的机制,给上级(父级)元素触发事件的dom对象上绑定一个处理函数.在当有需要很多dom对象要绑定事件的情况下,可以使用事件 ...

  6. 简易页面场景滚动的jquery插件

    (function($){ $.extend($.fn, { scene_scroll:function(arg_obj){ // 参数检测 // 场景数组 var $scene_arr = arg_ ...

  7. Android &colon; 按 Back 按钮不返回处于后台的 Activity

    在一个项目中,我有一种情况下启动一个新 Activity 后,按 Back 按钮时不想返回到后台的 Activity. 具体方法是, 在启动新的 Activity 的时候: Intent intent ...

  8. Linux之shell

    shell的中文意思是外壳. 通常在图形界面中对实际体验带来的差异不是不同发行版本的终端模拟器,而是shell这个壳. 壳在核外,shell里面的核就是linux内核. shell指的是:提供给使用者 ...

  9. Win10英文系统 JDK1&period;8安装及环境变量配置

    前提 今天换新电脑了,需要重新安装一遍JDK.写个随笔记录一下整个过程. 下载 官网上JDK已经出到10了,但是回忆起JDK9都有各种坑(不支持一些软件),决定还是用JDK8. 下载地址: http: ...

  10. JavaScript------Throw和Try-Catch的使用

    function test() { try { var x = document.getElementById("demo").value; if (x == "&quo ...