TypeScript - สหภาพ

TypeScript 1.4 ช่วยให้โปรแกรมสามารถรวมหนึ่งหรือสองประเภทได้ ประเภทยูเนี่ยนเป็นวิธีที่มีประสิทธิภาพในการแสดงมูลค่าซึ่งอาจเป็นหนึ่งในหลายประเภท ชนิดข้อมูลตั้งแต่สองชนิดขึ้นไปจะรวมกันโดยใช้สัญลักษณ์ไปป์ (|) เพื่อแสดงถึงประเภทยูเนี่ยน กล่าวอีกนัยหนึ่งประเภทยูเนี่ยนถูกเขียนเป็นลำดับของประเภทที่คั่นด้วยแถบแนวตั้ง

ไวยากรณ์: Union literal

Type1|Type2|Type3

ตัวอย่าง: ตัวแปรประเภทสหภาพ

var val:string|number 
val = 12 
console.log("numeric value of val "+val) 
val = "This is a string" 
console.log("string value of val "+val)

ในตัวอย่างข้างต้นประเภทของตัวแปรคือยูเนี่ยน หมายความว่าตัวแปรสามารถมีตัวเลขหรือสตริงเป็นค่าได้

ในการคอมไพล์จะสร้างโค้ด JavaScript ต่อไปนี้

//Generated by typescript 1.8.10
var val;
val = 12;
console.log("numeric value of val " + val);
val = "This is a string";
console.log("string value of val " + val);

ผลลัพธ์มีดังนี้ -

numeric value of val  12 
string value of val this is a string

ตัวอย่าง: ประเภทยูเนี่ยนและพารามิเตอร์ฟังก์ชัน

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("mark") 
console.log("Printing names array....") 
disp(["Mark","Tom","Mary","John"])

ฟังก์ชัน disp () สามารถยอมรับอาร์กิวเมนต์ของสตริงชนิดหรือสตริงอาร์เรย์

ในการคอมไพล์จะสร้างโค้ด JavaScript ต่อไปนี้

//Generated by typescript 1.8.10
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("mark");
console.log("Printing names array....");
disp(["Mark", "Tom", "Mary", "John"]);

ผลลัพธ์มีดังนี้ -

Mark 
Printing names array…. 
Mark 
Tom
Mary
John

ประเภทสหภาพและอาร์เรย์

ประเภทยูเนี่ยนสามารถใช้กับอาร์เรย์คุณสมบัติและอินเทอร์เฟซได้ ต่อไปนี้แสดงให้เห็นถึงการใช้ชนิดยูเนียนกับอาร์เรย์

ตัวอย่าง: Union Type และ Array

var arr:number[]|string[]; 
var i:number; 
arr = [1,2,4] 
console.log("**numeric array**")  

for(i = 0;i<arr.length;i++) { 
   console.log(arr[i]) 
}  

arr = ["Mumbai","Pune","Delhi"] 
console.log("**string array**")  

for(i = 0;i<arr.length;i++) { 
   console.log(arr[i]) 
}

โปรแกรมประกาศอาร์เรย์ อาร์เรย์สามารถแสดงคอลเล็กชันตัวเลขหรือคอลเล็กชันสตริง

ในการคอมไพล์จะสร้างโค้ด JavaScript ต่อไปนี้

//Generated by typescript 1.8.10
var arr;
var i;
arr = [1, 2, 4];
console.log("**numeric array**");

for (i = 0; i < arr.length; i++) {
   console.log(arr[i]);
}
arr = ["Mumbai", "Pune", "Delhi"];
console.log("**string array**");

for (i = 0; i < arr.length; i++) {
   console.log(arr[i]);
}

ผลลัพธ์มีดังนี้ -

**numeric array** 
1 
2 
4 
**string array** 
Mumbai 
Pune 
Delhi