TypeScript switch-satsen kör en sats från flera villkor. Den utvärderar ett uttryck baserat på dess värde som kan vara booleskt, tal, byte, kort, int, långt, enumtyp, sträng, etc. En switch-sats har ett kodblock som motsvarar varje värde. När matchningen hittas kommer motsvarande block att exekveras. En switch-sats fungerar som if-else-if ladder-satsen.
Följande punkter måste komma ihåg i en switch-sats:
- Det kan finnas N antal fall i en switch-sats.
- Fallvärdena måste vara unika.
- Fallvärdena måste vara konstanta.
- Varje fallsats har en break-sats i slutet av koden. Paussatsen är valfri.
- Switch-satsen har ett standardblock som skrivs i slutet. Standardsatsen är valfri.
Syntax
switch(expression){ case expression1: //code to be executed; break; //optional case expression2: //code to be executed; break; //optional ........ default: //when no case is matched, this block will be executed; break; //optional }
Switch-satsen innehåller följande saker. Det kan finnas hur många fall som helst i en switch-sats.
Fall: Kassetten ska följas av endast en konstant och sedan ett semikolon. Den kan inte acceptera en annan variabel eller uttryck.
Ha sönder: Pausen bör skrivas i slutet av blocket för att komma ut från switch-satsen efter exekvering av ett fallblock. Om vi inte skriver break fortsätter exekveringen med matchningsvärdet till efterföljande fallblock.
Standard: Standardblocket ska skrivas i slutet av switch-satsen. Det körs när det inte finns några fall kommer att matchas.
Exempel
let a = 3; let b = 2; switch (a+b){ case 1: { console.log('a+b is 1.'); break; } case 2: { console.log('a+b is 5.'); break; } case 3: { console.log('a+b is 6.'); break; } default: { console.log('a+b is 5.'); break; } }
Produktion:
Växellåda med String
let grade: string = 'A'; switch (grade) { case'A+': console.log('Marks >= 90'+' '+'Excellent'); break; case'A': console.log('Marks [ >= 80 and = 70 and = 60 and <70 ]'+' '+'average'); break; case'c': console.log('marks < 60'+' '+'below average'); default: console.log('invalid grade.'); } pre> <p>In this example, we have a string variable grade. The switch statement evaluates grade variable value and match with case clauses and then execute its associated statements.</p> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/typescript-tutorial/79/typescript-switch-statement-3.webp" alt="TypeScript Switch Statement"> <hr> <h2>Switch Case with Enum</h2> <p>In TypeScript, we can use the switch case with Enum in the following ways.</p> <h3>Example</h3> <pre> enum Direction { East, West, North, South }; var dir: Direction = Direction.North; function getDirection() { switch (dir) { case Direction.North: console.log('You are in North Direction'); break; case Direction.East: console.log('You are in East Direction'); break; case Direction.South: console.log('You are in South Direction'); break; case Direction.West: console.log('You are in West Direction'); break; } } getDirection(); </pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/typescript-tutorial/79/typescript-switch-statement-4.webp" alt="TypeScript Switch Statement"> <hr> <h2>TypeScript Switch Statement is fall-through.</h2> <p>The TypeScript switch statement is fall-through. It means if a break statement is not present, then it executes all statements after the first match case.</p> <h3>Example</h3> <pre> let number = 20; switch(number) { //switch cases without break statements case 10: console.log('10'); case 20: console.log('20'); case 30: console.log('30'); default: console.log('Not in 10, 20 or 30'); } </pre> <p> <strong>Output:</strong> </p> <img src="//techcodeview.com/img/typescript-tutorial/79/typescript-switch-statement-5.webp" alt="TypeScript Switch Statement"></70>
Produktion:
TypeScript Switch Statement faller igenom.
TypeScript-växlingssatsen faller igenom. Det betyder att om en break-sats inte finns, så exekverar den alla uttalanden efter det första matchningsfallet.
Exempel
let number = 20; switch(number) { //switch cases without break statements case 10: console.log('10'); case 20: console.log('20'); case 30: console.log('30'); default: console.log('Not in 10, 20 or 30'); }
Produktion:
70>