TypeScript 第十天,TypeScript面向对象之Class(二)

接口

Interface接口的作用类似于抽象类,不同点在于接口中的所有方法和属性都是没有实值的,换句话说接口中的所有方法都是抽象方法。接口主要负责定义一个类的结构,接口可以去限制一个对象的接口,对象只有包含接口中定义的所有属性和方法时才能匹配接口。同时,可以让一个类去实现接口,实现接口时类中要保护接口中的所有属性。我们来看下面这个例子:

TypeScript 复制代码
interface Person{
    name: string;
    sayHello():void;
}

function fn(per: Person){
    per.sayHello();
}

fn({name:'孙悟空', sayHello() {console.log(`Hello, 我是 ${this.name}`)}});

这里注意接口中只有我们的对象方法,没有具体的实现,实现都是在类中使用implements来实现的,我们看下面例子:

TypeScript 复制代码
// 接口中所有的方法都是抽象方法
    interface myInter{
        name: string;
        sayHello(): void;
    }

    class MyClass implements myInter{
        name: string;
        constructor(name: string) {
            this.name = name;
        }
        sayHello(): void {
            console.log('hello');
        }
    }  

泛型(Generic)

定义一个函数或类时,有些情况下无法确定其中要使用的具体类型(返回值、参数、属性的类型不能确定),此时泛型便能够发挥作用。我们看下面例子:

TypeScript 复制代码
function test(arg: any): any{
	return arg;
}

假如我们使用上面例子中的方式,能确定的入参和出参都是任意的,并不能保证是同一种数据类型,所以我们就可以使用泛型,再看一个例子:

TypeScript 复制代码
function test<T>(arg: T): T{
	return arg;
}

上面内容,是可以保证我们的入参和出参都是一致的数据类型,这里的<T>就是指泛型。 使用上面泛型有两种方式

1.直接使用

TypeScript 复制代码
test(10)

2.指定类型

TypeScript 复制代码
test<number>(10)

也可以时指定多个类型

TypeScript 复制代码
function test<T, K>(a: T, b: K): K{
    return b;
}

test<number, string>(10, "hello");

这里说一个小技巧:使用泛型时,完全可以将泛型当成是一个普通的类去使用

类中同样可以使用泛型

TypeScript 复制代码
class MyClass<T>{
    prop: T;

    constructor(prop: T){
        this.prop = prop;
    }
}

也可以对泛型的类型进行约束

TypeScript 复制代码
interface MyInter{
    length: number;
}

function test<T extends MyInter>(arg: T): number{
    return arg.length;
}

index.less

less 复制代码
@bg-color:#b7d4a8;
*{
    padding: 0;
    margin: 0;
    box-sizing: border-box;
}

body{
    font:bold 20px "Courier";
    overflow: hidden;
}

// 设置主窗口的样式
#main{
    width: 360px;
    height: 420px;
    background-color: @bg-color;
    margin: 100px auto;
    border: 10px solid black;
    border-radius: 40px;

    display: flex;
    flex-flow: column; // 默认是row方向排列,这里改成column 方向

    align-items: center;
    justify-content: space-around;

    #stage{
        width: 304px;
        height: 304px;
        border:2px solid black;
        position: relative;
        #sink{
            &>div{
               width: 10px;
               height: 10px;
               background-color: black; 
               border: 1px solid @bg-color;
               position: absolute;
            }
        }
        #food{
            width: 10px;
            height: 10px;
            position: absolute;
            left: 40px;
            top: 100px;
// background-color: red;
display: flex;
flex-flow: row wrap;
justify-content: space-between;
align-content: space-between;
            &>div{
                 width: 4px;
                 height: 4px;
                 background-color:black;
                 transform:rotate(45deg);
            }
        }
    }
    #score-panel{
        width: 300px;
        display: flex;
        justify-content: space-between;
    }
}

使用T extends MyInter表示泛型T必须是MyInter的子类,不一定非要使用接口类和抽象类同样适用。

感谢大家观看,我们下次见

相关推荐
帧栈3 小时前
开发避坑指南(27):Vue3中高效安全修改列表元素属性的方法
前端·vue.js
max5006003 小时前
基于桥梁三维模型的无人机检测路径规划系统设计与实现
前端·javascript·python·算法·无人机·easyui
excel3 小时前
使用函数式封装绘制科赫雪花(Koch Snowflake)
前端
萌萌哒草头将军4 小时前
Node.js v24.6.0 新功能速览 🚀🚀🚀
前端·javascript·node.js
持久的棒棒君5 小时前
启动electron桌面项目控制台输出中文时乱码解决
前端·javascript·electron
小离a_a6 小时前
使用原生css实现word目录样式,标题后面的...动态长度并始终在标题后方(生成点线)
前端·css
郭优秀的笔记7 小时前
抽奖程序web程序
前端·css·css3
布兰妮甜7 小时前
CSS Houdini 与 React 19 调度器:打造极致流畅的网页体验
前端·css·react.js·houdini
小小愿望7 小时前
ECharts 实战技巧:揭秘 X 轴末项标签 “莫名加粗” 之谜及破解之道
前端·echarts
小小愿望7 小时前
移动端浏览器中设置 100vh 却出现滚动条?
前端·javascript·css