zoukankan      html  css  js  c++  java
  • TypeScript快速笔记(二)

    1) TypeScript中的判断语句,可以使用非0值代表true。如:

     1 function add1(a: number, b?:number): number{ // 注意b是可选参数
     2     console.log("parm1(a): " + a, "parm2(b): " + b);
     3     if(b){// 可选参数b,如果没有传参,值为undefined
     4         return a + b;
     5     }
     6     else{
     7         return a;
     8     }
     9 }
    10 console.log(add1(10, 20)); // a: 10, b: 20
    11 console.log(add1(25)); // a: 25, b: undefined
    12 
    13 var num: number = 5;
    14 if (num){
    15     console.log('非0就是true') // 执行
    16 }
    17 num = 0;
    18 if (num){
    19     console.log('Test'); // 不会执行
    20 }
    21 
    22 if (null){
    23     console.log('null') // 不会执行
    24 }
    25 if (undefined){
    26     console.log('undefined') // 不会执行
    27 }
    非0判断

    2)函数的定义有多种:无参函数,有参函数,可选函数,默认参数(与C/C++类似),剩余参数(类似于C/C++的可变参数),匿名函数,构造函数,递归函数,Lambda函数

    普通参数的定义方式:

    function functionName(){}
    function functionName(parm1: [type], parm2: [type]): returnType{}

     可选参数的定义方式:

    function functionName(parm1:[type], parm2?: [type]): returnType{} // 在可选参数后面加‘?’

    实例:

     1 console.log("普通参数测试:");
     2 function add(a: number, b: number): number{
     3     return a + b;
     4 }
     5 
     6 console.log(add(5, 7));
     7 
     8 // 可选参数,当没有传进可选参数时,参数值为undefined
     9 console.log("可选参数测试:");
    10 function add1(a: number, b?:number): number{
    11     console.log("parm1(a): " + a, "parm2(b): " + b);
    12     if(b){// 可选参数b,如果没有传参,值为undefined
    13         return a + b;
    14     }
    15     else{
    16         // NaN代表一个非数字值
    17         console.log(isNaN(a + b)); // true
    18         console.log(isNaN(undefined)); // true
    19         console.log(isNaN(null)); // false, null不是NaN值
    20 
    21         return a;
    22     }
    23 }
    24 
    25 console.log(add1(10, 20));
    26 console.log(add1(25));
    27 
    28 
    29 // 剩余参数
    30 console.log("剩余参数测试:");
    31 function sum(...num: number[]){
    32     let sum: number = 0;
    33     let resultString: string = '';
    34     for(let i = 0; i < num.length; ++i){
    35         sum += num[i];
    36         resultString += num[i];
    37         if (i + 1 < num.length)
    38             resultString += ' + ';
    39         else
    40             resultString += ' = ';
    41     }
    42     resultString += sum;
    43     console.log(resultString);
    44     return sum;
    45 }
    46 
    47 sum(1,2,3,4,5);
    48 
    49 //匿名函数
    50 // 除了没有函数名外,其他的与标准函数一样。将匿名函数赋值给一个变量,这种表达式就成为函数表达式。
    51 var res = function(a: number, b: number): number{
    52     return a + b;
    53 }
    54 
    55 console.log(res(1, 5));
    56 
    57 // 匿名函数自调用,在函数后面加个圆括号即可
    58 (function(){
    59     console.log("Hello World!");
    60 })();
    函数

    结果:

    普通参数测试:
    12
    可选参数测试:
    parm1(a): 10 parm2(b): 20
    30
    parm1(a): 25 parm2(b): undefined
    true
    true
    false
    25
    剩余参数测试:
    1 + 2 + 3 + 4 + 5 = 15
    6
    Hello World!
    函数实例输出结果

    补充:关于重载函数,除了使用any,也可以使用联合类型,即:function disp(x:string|number,y?:string|number):void{}

     3)TypeScript中的重载不是真正意义的重载,不能想C++/C#等方式直接重载,否则编译时会出现报错:TS2396: Duplicate function implementation.

      TypeScript重载方式:

        *如果参数类型不同,则参数类型应设置为 any

        *参数数量不同你可以将不同的参数设置为可选。

     1 // 函数重载
     2 function disp(s1:string):void;  // 先声明重载函数但是不定义(函数签名)
     3 function disp(n1:number,s1:string):void;
     4 function disp(s1:string,n1:number):void;
     5  
     6 // 根据函数重载方式的实际情况,函数体的类型判断也可以做出优化
     7 function disp(x:any,y?:any):void { // 通过any类型和可选参数实现重载
     8     if(typeof(x) == "string" && typeof(y) == "undefined"){
     9         console.log('(string): ' + x);
    10     }
    11     else if(typeof(x) == 'number' && typeof(y) == 'string'){
    12         console.log('(number, string):' + x + ',' + y);
    13     }
    14     else if(typeof(x) == 'string' && typeof(y) == 'number'){
    15         console.log('(string, number):' + x + ',' + y);
    16     }
    17 } 
    18 disp("abc"); // 输出:(string): abc
    19 disp(1,"xyz"); // 输出:(number, string):1,xyz
    20 disp("hello", 100); // 输出:(string, number):hello,100
    21 //disp(1, 1); // 类型不匹配会报错:TS2345: Argument of type '1' is not assignable to parameter of type 'string'.
    函数重载

    4)Number对象是原始数值number的包装对象,封装了更多的方法。

     1 // Number对象测试
     2 // Number对象是原始数值的包装对象
     3 var num1: number = 100;
     4 var num2 = new Number(num1); 
     5 var num3 = new Number('123'); // 可以接受字符串转换
     6 var num4 = new Number(null); // 0
     7 var num5 = new Number('0xA'); // 十六进制,等于十进制的10
     8 var num6 = new Number('123a'); //  如果一个参数值不能转换为一个数字将返回非数字值 NaN (Not a Number)
     9 
    10 console.log('Test typeof:');
    11 console.log(typeof num1); // 输出:number
    12 console.log(typeof num2); // Number是一个对象,输出:object
    13 console.log(typeof num3); // 输出:object
    14 console.log(typeof num4); // 输出:object
    15 console.log(typeof num5); // 输出:object
    16 console.log(typeof num6); // 输出:object
    17 
    18 console.log('Value test:');
    19 console.log(num1.toString()); // 100
    20 console.log(num2.toString()); // 100
    21 console.log(num3.toString()); // 123
    22 console.log(num4.toString()); // 0
    23 console.log(num5.toString()); // 10
    24 console.log(num6.toString()); // NaN
    25 
    26 //console.log(num2 + num3); 编译错误,TS2365: Operator '+' cannot be applied to types 'Number' and 'Number'.
    number类型和Number对象测试
  • 相关阅读:
    [JavaEE] Hibernate ORM
    [PHP] htaccess 探秘
    [JavaEE] SSH框架搭建所需要的包
    博客园使用技巧
    vs快捷键
    算法:递归、循环、迭代、哈希表、查找、内排序、外排序
    【译】.NET中六个重要的概念:栈、堆、值类型、引用类型、装箱和拆箱 --转载
    .NET框架与开发语言:相关框架、共用部分、开发语言、一些疑问
    c#原理:c#代码是怎么运行的、实例化时发生了什么、静态对象(类、方法、变量、属性)的原理
    EA:UML建模-流程图、时序图、部署图
  • 原文地址:https://www.cnblogs.com/SunboyL/p/11518403.html
Copyright © 2011-2022 走看看