Typescript中类、接口、泛型综合使用

  • 功能: 定义一个操作,支持mysql, mssql, mongodb
  • 要求: mysql, mussel, mongodb功能一样,都有add, update, delete, get方法
  • 注意: 约束统一的规范,代码重用
  • 解决方案: 需要约束规范所以要定义接口,需要代码重用,所以需要用到泛型
    1. 接口:在面向对象的编程中,接口是一种规范的定义,它定义了行为和动作的规范
    2. 泛型:泛型就是解决类、接口、方法的复用性。
interface DB<T>{
    add(info:T):boolean;
    update(info:T,id:number):boolean;
    delete(info:T,id:number):boolean;
    get(info:T, id:number):any[];
}

//定义一个操作mysql数据库的类
//注意:要实现泛型接口,类也应该是泛型类
class MySqlDB<T> implements DB<T>{
    add(info: T): boolean {
        return true;
    }    
    update(info: T, id: number): boolean {
        return true;
    }
    delete(info:T, id: number): boolean {
        return true;
    }
    get(info: T, id: number): any[] {
        let result = [
            {username:"test1", password:"123456",id:1},
            {username:"test2", password:"123456",id:2},
            {username:"test3", password:"123456",id:3},
            {username:"test4", password:"123456",id:4}
        ];
        return result;
    }


}

//定义一个操作mssql数据库的类
class MsSqlDB<T> implements DB<T>{
    add(info: T): boolean {
        throw new Error("Method not implemented.");
    }    
    update(info: T, id: number): boolean {
        return true;
        throw new Error("Method not implemented.");
    }
    delete(info: T, id: number): boolean {
        throw new Error("Method not implemented.");
    }
    get(info: T, id: number): any[] {
        
        throw new Error("Method not implemented.");
    }
}

//定义一个操作mongodb数据库的类
class MongoDB<T> implements DB<T>{
    add(info: T): boolean {
        throw new Error("Method not implemented.");
    }    
    update(info: T, id: number): boolean {
        throw new Error("Method not implemented.");
    }
    delete(info: T, id: number): boolean {
        throw new Error("Method not implemented.");
    }
    get(info: T, id: number): any[] {
        throw new Error("Method not implemented.");
    }
}

class User{
    username:string | undefined;
    password:string | undefined;
}

let user1 = new User();
user1.username = "zhangsan";
user1.password = "123456";

let mysqldb = new MySqlDB<User>();
mysqldb.add(user1);
mysqldb.update(user1,1);
console.log(mysqldb.get(user1,1));
console.log(mysqldb.delete(user1,1));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值