前端面试题精心整理(一)-TypeScript

文章目录

    • TypeScript相关问题及知识点
      • Q1: ts中type和interface的区别?
      • A1: 有相同点与不同点,具体内容如下。
      • Q2: ts中interface和class的区别? 分别什么时候使用?
      • A2: interface和class都能定义数据模型。区别:……
      • Q3: ts中的泛型有什么了解?
      • A3: 案例
        • 1. 不用泛型的话,这个函数可能是下面这样:
        • 2. 泛型的使用方法有两种:

TypeScript相关问题及知识点

Q1: ts中type和interface的区别?

A1: 有相同点与不同点,具体内容如下。

1. 相同点
(1) 两者都可以定义对象和函数。

interface:

 interface Person{
  name: string;
  age: number;
}
interface SetPerson {
  (name: string, age: number): void;
}

type:

type Person= {
  name: string;
  age: number
};
type SetPerson = (name: string, age: number)=> void;

(2) 都可以继承。
interface 定义的对象用extends继承,type&继承。二者之间可以用前面提到的自己的语法互相继承。

2. 不同点:
(1)interface可以声明合并,即声明了多个同样名称的接口可以合并成一个,而type不行。

interface Pesron{
  name: string;
  age: number;
}
interface Person{
  sex: string;
}
/*
Person接口为 {
  name: string;
  age: number;
  sex: string ;
}
*/

(2) type可以声明:基本类型的别名、联合类型、元组等类型,而interface不行。

 // 别名
type Empty=null;
// 联合类型
interface Person1{
	sayHi();
}
interface Person2{
	eat();
}
type Person = Person1 | Person2;
type ex = number | string;
// 元组 数组中元素的数据类型都一般是相同的(any[] 类型的数组可以不同),如果存储的元素数据类型不同,则需要使用元组。
type tuple=[1,'good'];
//type 语句中可以使用 typeof 获取实例的类型进行赋值
let tem = new Number();
type B = typeof tem;

(3)还有其他复杂操作,泛型等。

Q2: ts中interface和class的区别? 分别什么时候使用?

A2: interface和class都能定义数据模型。区别:……

区别:interface只是用来声明对象类型或方法,不做实现;而class是类的声明并实现。

  • 简单的数据模型,直接用于展示的,用 interface 进行定义;
  • 比较复杂的数据模型,有字段属性定义以及一些方法,就需要使用 class 。里面还有constructor构造函数。
  • interface 只在编译时用于类型检查,class 编译完成之后实际上就是 javascript 中的原型(prototype)。
    接口可以通过extends继承类,类可以通过implements去实现接口。有个很好的例子帮助理解。

Q3: ts中的泛型有什么了解?

A3: 案例

1. 不用泛型的话,这个函数可能是下面这样:

function identity(arg: number): number {
    return arg;
}

或者,我们使用any类型来定义函数:

function identity(arg: any): any {
    return arg;
}

any的情况,可以是任何类型。因此,我们需要一种方法使返回值的类型传入参数的类型是相同的。 这时,就用到了T,类型变量,它是一种特殊的变量,只用于表示类型而不是值。

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

这样就可以跟踪函数里使用的类型信息

2. 泛型的使用方法有两种:

此处参考官方文档改写。
(1) 尖括号的形式:
let output = identity< string> (“myString”);// type of output will be ‘string’
这里明确的指定了Tstring类型,并做为一个参数传给函数,使用了<>括起来。

(2) 利用了类型推论,即编译器会根据传入的参数自动地帮助我们确定T的类型:
let output = identity(“myString”); // type of output will be ‘string’

本文为原创文章,转载请注明出处。

你可能感兴趣的:(前端,TypeScript,typescript,前端,ts,javascript)