zoukankan      html  css  js  c++  java
  • ts中泛型、泛型方法、泛型类、泛型接口

    什么是泛型呢?我们可以理解为泛型就是在编译期间不确定方法的类型(广泛之意思),在方法调用时,由程序员指定泛型具体指向什么类型。泛型在传统面向对象编程语言中是极为常见的,ts中当然也执行泛型,如果你理解c#或java中的泛型,相信本篇理解起来会很容易。

    泛型函数、泛型类、泛型接口。

    08_generic.ts

    /*
    * ts中泛型
    * 泛型就是在编译期间不确定方法的类型(广泛之意思),在方法调用时,由程序员指定泛型具体指向什么类型
    */

    
    
    /*
     * ts中泛型
     *    泛型就是在编译期间不确定方法的类型(广泛之意思),在方法调用时,由程序员指定泛型具体指向什么类型
     */
     
    //1 泛型函数
     
    /**
     * 获取数组中最小值 (数字)
     * @param {number[]} arr
     * @returns {number}
     */
    function  getMinNumber(arr:number[]):number{
        var min=arr[0];
        arr.forEach((value)=>{
            if(value<min){
                min=value;
            }
        });
        return min;
    }
     
    /**
     * 获取数组中最小值 (字符串)
     * @param {number[]} arr
     * @returns {number}
     */
    function  getMinStr(arr:string[]):string{
        var min=arr[0];
        arr.forEach((value)=>{
            if(value<min){
                min=value;
            }
        });
        return min;
    }
     
    console.log(getMinNumber([1, 3, 5, 7, 8]));//1
    console.log(getMinStr(["tom","jerry","jack","sunny"]));//jack
     
    /**
     * 获取数组中最小值 (T泛型通用)
     * @param {T[]} arr
     * @returns {T}
     */
    function getMin<T>(arr:T[]):T{
       var min=arr[0];
       arr.forEach((value)=>{
          if(value<min){
              min=value;
          }
       });
        return min;
    }
     
    console.log(getMin([1, 3, 5, 7, 8]));
    console.log(getMin(["tom","jerry","jack","sunny"]));
     
     
    //2 泛型类
    class GetMin<T>{
         arr:T[]=[];
         add(ele:T){
             this.arr.push(ele);
         }
        min():T{
           var min=this.arr[0];
           this.arr.forEach(function (value) {
              if(value<min){
                  min=value;
              }
           });
           return min;
        }
    }
      var gm1= new  GetMin<number>();
       gm1.add(5);
       gm1.add(3);
       gm1.add(2);
       gm1.add(9);
    console.log(gm1.min());
     
    var gm2= new  GetMin<string>();
    gm2.add("tom");
    gm2.add("jerry");
    gm2.add("jack");
    gm2.add("sunny");
    console.log(gm2.min());
     
     
     
    /**
     * 3 泛型函数接口
     */
    interface ConfigFn{
        <T>(value:T):T;
    }
     
    var getData:ConfigFn=function<T>(value:T):T{
        return value;
    }
    getData<string>('张三');
    // getData<string>(1243);  //错误
     
     
    // 类似  Map<String,Object> Param  接口
    interface Param{
        [index:string]:any
    }
     
     
     
    //4 泛型类接口
     
    /**
     * page分页对象
     */
    class Page{
        private currentPage:number=1; //当前页码 默认1
        private pageSize:number=10;//每页条数 默认为10
        private sortName:string; //排序字段
        private sortOrder:string="asc"; // 排序规则 asc | desc 默认为asc正序
     
     
         constructor(param:Param){
             if(param["currentPage"]){
                 this.currentPage=param["currentPage"];
             }
             if(param["pageSize"]){
                 this.pageSize=param["pageSize"];
             }
             if(param["sortName"]){
                 this.sortName=param["sortName"];
             }
             if(param["sortOrder"]){
                 this.sortOrder=param["sortOrder"];
             }
         }
     
        public    getStartNum():number{
            return   (this.currentPage-1)*this.pageSize;
        }
    }
     
     
    class User{
         id:number;//id主键自增
         name:string;//姓名
         sex:number;//性别 1男 2女
         age:number;//年龄
         city:string;//城市
         describe:string;//描述
     
    }
     
    //泛型接口
    interface  BaseDao<T> {
         findById(id:number):T;//根据主键id查询一个实体
         findPageList(param:Param,page:Page):T[];//查询分页列表
         findPageCount(param:Param):number;//查询分页count
         save(o:T):void;//保存一个实体
         update(o:T):void;//更新一个实体
         deleteById(id:number);//删除一个实体
    }
     
    /**
     * 接口实现类
     */
    class UserDao<User> implements BaseDao<User>{
         findById(id:number):User{
     
            return null;
         }
        findPageList(param:Param,page:Page):User[]{
             return [];
        }
        findPageCount(param:Param):number{
             return   0;
        }
        save(o:User):void{
     
        }
        update(o:User):void{
     
        }
        deleteById(id:number){
     
        }
    }
    
    
    
    
    
  • 相关阅读:
    Linux0.11之初识Makefile/build.c
    主机(windows10)虚拟机(ubuntu18)arm板(linux3.4)相互ping通
    windows上利用dhcpsrv搭建DHCP服务器
    《剑指offer》面试题27 二叉搜索树与双向链表 Java版
    《剑指offer》面试题26 复杂链表的复制 Java版
    《剑指offer》面试题25 二叉树中和为某一值的路径 Java版
    《剑指offer》面试题24 二叉搜索树的后序遍历序列 Java版
    异常处理
    三元表达式、列表推导式、生成器表达式、匿名函数、内置函数、递归调用与二分法的简单认识
    迭代器与生成器
  • 原文地址:https://www.cnblogs.com/plBlog/p/12365627.html
Copyright © 2011-2022 走看看