zoukankan      html  css  js  c++  java
  • ts 联合类型

    转载自:https://www.runoob.com/typescript/ts-union.html

    联合类型(Union Types)可以通过管道(|)将变量设置多种类型,赋值时可以根据设置的类型来赋值。

    联合类型变量定义

    注意:只能赋值指定的类型,如果赋值其它类型就会报错。

    创建联合类型的语法格式如下:

    Type1|Type2|Type3 
    

    实例

    声明一个联合类型:

    var val:string|number 
    val = 12 
    console.log("数字为 "+ val) 
    val = "Runoob" 
    console.log("字符串为 " + val)
    

    编译以上代码,得到以下 JavaScript 代码:

    var val;
    val = 12;
    console.log("数字为 " + val);
    val = "Runoob";
    console.log("字符串为 " + val);
    

    如果赋值其它类型就会报错:

    var val:string|number 
    val = true 
    

    联合类型作为函数参数

    也可以将联合类型作为函数参数使用:

    function disp(name:string|string[]) { 
            if(typeof name == "string") { 
                    console.log(name) 
            } else { 
                    var i; 
                    for(i = 0;i<name.length;i++) { 
                    console.log(name[i])
                    } 
            } 
    } 
    disp("Runoob") 
    console.log("输出数组....") 
    disp(["Runoob","Google","Taobao","Facebook"])
    

    编译以上代码,得到以下 JavaScript 代码:

    function disp(name) {
            if (typeof name == "string") {
                    console.log(name);
            }
            else {
                    var i;
                    for (i = 0; i < name.length; i++) {
                    console.log(name[i]);
                    }
            }
    }
    disp("Runoob");
    console.log("输出数组....");
    disp(["Runoob", "Google", "Taobao", "Facebook"]);
    

    输出结果为:

    Runoob
    输出数组....
    Runoob
    Google
    Taobao
    Facebook
    

    联合类型数组

    我们也可以将数组声明为联合类型:

    var arr:number[]|string[]; 
    var i:number; 
    arr = [1,2,4] 
    console.log("**数字数组**")  
     
    for(i = 0;i<arr.length;i++) { 
       console.log(arr[i]) 
    }  
     
    arr = ["Runoob","Google","Taobao"] 
    console.log("**字符串数组**")  
     
    for(i = 0;i<arr.length;i++) { 
       console.log(arr[i]) 
    }
    

    编译以上代码,得到以下 JavaScript 代码:

    var arr;
    var i;
    arr = [1, 2, 4];
    console.log("**数字数组**");
    for (i = 0; i < arr.length; i++) {
        console.log(arr[i]);
    }
    arr = ["Runoob", "Google", "Taobao"];
    console.log("**字符串数组**");
    for (i = 0; i < arr.length; i++) {
        console.log(arr[i]);
    }
    

    输出结果为:

    **数字数组**
    1
    2
    4
    **字符串数组**
    Runoob
    Google
    Taobao
    
  • 相关阅读:
    C#指南,重温基础,展望远方!(3)类型和变量
    C#指南,重温基础,展望远方!(2)程序结构
    C#指南,重温基础,展望远方!(1)C#语言介绍
    ASP.NET MVC 简单的分页思想与实现
    ASP.NET MVC实现网站验证码功能
    hdu
    多种方法实现实现全排列 + sort调用标准函数库函数的简述
    HDU
    <hdu
    NYOJ-括号配对问题 <技巧性的非栈道法>
  • 原文地址:https://www.cnblogs.com/makalochen/p/14511665.html
Copyright © 2011-2022 走看看