Switch case enum typescript

Switch in TypeScript

The switch statement evaluates an expression, matches the value of the expression to a case clause, and executes the statements associated with that case, as well as statements in cases that follow the matching case.

Introduction to TypeScript Switch Case

Switch case in TypeScript is used to execute one statement from multiple conditions. The switch statement takes an expression and evaluates it with defined valid cases, and then returns the values associated with the case that matches the expression.

For example, We are making a website that displays the days of the week. The website will simply take any number from 1 to 7 as input and return the day associated with it. Hence, if we try to achieve the above situation with the help of an if-else statement, we have to write seven if statements where we’ll compare the variable with the number associated with each day of the week. As we can see the above process is complex, this type of situation can be handled by the Switch case.

Читайте также:  Html and script codes

Syntax of Switch Case

In the above syntax, if the expression value is equal to val1 then only the code block statement1 will be executed. We use break after every case as it is required to not execute other block statements. The default case will be executed when the expression doesn’t match with any other case. The default can come in any order but it is always executed at the last after all the cases are evaluated.

Rules that Apply to a Switch Statement

Various rules are applied on switch Statement in TypeScript:

  • The switch statement may have constant or variable expressions that return a value of any data type.
  • The break statement should be used at the end of each case block to stop the execution of the case block.
  • The return type of the case expression and switch expression should match.
  • The case expression must be unique.
  • In the switch expression, the default block is optional.
  • The case can have a constant or an expression and there can be any number of case statements within a switch.

Flowchart of Switch Case

Following is the flowchart that demonstrated the working of the Switch case in TypeScript:

Switch Case Flowchart

In the above flowchart, the switch case begins with an expression. The expression for case1 is evaluated. If the expression is passed, then the switch will execute block1 and the operation will be terminated.

If case1 fails, then the 2nd case will be evaluated. If the expression is passed then the switch case will evaluate block3 , and the operation will terminate otherwise, the expression will evaluate the next case, and so on. If no case passes the expression, then the switch statement will evaluate the default code.

How does Switch Case Statement Works in TypeScript?

The switch case takes an expression and checks for its equality. The expression can be a single integer, an enumerated value, or a string object. We use a break keyword to break the switch case. It is not mandatory to use, but if the break statement will not be there, the switch case will execute code statements that will be associated with all the cases that evaluate the expression true.

In the end, we use a default statement that is equivalent to the else of the if-else statement. It is not mandatory to use but it is used to execute a code if no case is found to be true.

Lexical Scoping

The case and default cases are like labels: they indicate possible places that control flow may jump to. Hence, they don’t create lexical scopes.

In the above snippet, an error will occur Uncaught SyntaxError: Identifier ‘message’ has already been declared . This is because the first const message = ‘hi’; is creating a conflict with the second const message = ‘hello’; even when they are declared within their separate case clauses. This error is occurring as both const declarations are within the same block scope that is created by the switch body.

This error can be fixed by wrapping the conditions in a block, and let and const declarations should be enclosed in a case clause.

The above snippet will print Hi in the console as the output without any errors.

TypeScript Switch Case Statement Examples

TypeScript Switch Case Statement

In the above snippet, we have a variable, the day of the type number. The variable is declared with the value 6 . The value corresponds to the day of the week. The switch statement checks the value passed and executes the block of code corresponding to that value. Hence, we get the result Today is Saturday .

Grouping Case

In grouping cases, we can group a piece of code that is being shared by multiple cases.

In the above snippet, if the month is 1 , 3 , 5 , 7 , 8 , or 12 then the number of days is 31 . If the month is 4 , 6 , 9 , or 11 then the number of days is 30 . If the month is 2 and the year is a leap year, it returns 29 days otherwise, it returns 28` days.

Switch Case with Enum

A switch case in TypeScript can be used with an enum with the following example:

In the above snippet, the fru variable is an enum type. It will be passed to the switch statement. In the switch clause, we will write the enum members for matching.

Switch Case with String

A switch case in TypeScript can be used with string with the following example:

In the above snippet, we have a string variable dir . The switch statement evaluates the dir variable value and match it with the case clauses and executes its associated statements.

Taking Advantage of Fall-Through

In the above snippet, we have a string variable dir . The switch statement evaluates the dir variable value and matches with the case clauses and executes its associated statements.

The following example given is a single operation sequential case statement where three different values perform the same operation.

Browser Compatibility of Switch Case Statement

Switch Case Browser Compatibility

Conclusion

  • The switch case in TypeScript is used when we have to move differently for different cases of an expression.
  • The switch statement takes an expression and evaluates it for all the cases and executes the code statement that is associated with the matching case.
  • In this article, we were able to see the working of the Switch Case statement and the rules that apply to the switch case.
  • We can use the default statement if all the cases fail to satisfy the expression.
  • We can use the break keyword to stop the execution of the switch case when it has processed the code statement that is associated with the matching case.
  • The switch case can be considered as an alternative to if-else statements.
  • Hope this article has provided you with the relevant information regarding Switch Statement in TypeScript.

Источник

Switch case enum typescript

Last updated: Jan 20, 2023
Reading time · 2 min

banner

# Use a Switch statement with Enums in TypeScript

To use a switch statement with enums:

  1. Create a reusable function that takes an enum value as a parameter.
  2. Use a switch statement and switch on the provided value.
  3. Return a specific value from each branch.
Copied!
enum Sizes Small, Medium, > function getSize(size: Sizes) switch (size) case Sizes.Small: console.log('small'); return 'S'; case Sizes.Medium: console.log('medium'); return 'M'; default: throw new Error(`Non-existent size in switch: $size>`); > > console.log(getSize(Sizes.Small)); // 👉️ "S" console.log(getSize(Sizes.Medium)); // 👉️ "M"

We created a reusable function that takes an enum value as a parameter, switches on the enum value before returning something else.

The default case is a matter of implementation. In the example, we throw an error to indicate that an unexpected state has occurred — the passed-in value is not present in the enum.

# Use a Switch statement with Numeric Enums in TypeScript

If you have a numeric enum and you try to use a switch statement directly, you might get an error that «Type X is not compatible to type Y».

In this scenario, you can convert the enum value to a number when switching on it.

Copied!
enum Sizes Small, Medium, > switch (Number(Sizes.Small)) case Sizes.Small: // 👇️ this runs console.log('size is S'); break; case Sizes.Medium: console.log('size is M'); break; default: console.log(`non-existent size: $Sizes.Small>`); break; >

Had we not converted the enum value to a number when switching on it, we would get an error that the two types are not compatible.

Make sure to always use the break keyword to avoid a fallthrough switch which could run multiple code blocks.

If you’re in a function, you will most likely use return instead of break .

# Use conversion to String if necessary

If you are getting a similar error when working with string enums, you can convert the value to a string in the switch statement.

Copied!
enum Sizes Small = 'S', Medium = 'M', > switch (String(Sizes.Small)) case Sizes.Small: console.log('size is S'); break; case Sizes.Medium: console.log('size is M'); break; default: console.log(`non-existent size: $Sizes.Small>`); break; >

If you run the code from the example above, the size is S message gets logged to the console.

If you get the Conversion of type ‘X’ to type ‘Y’ may be a mistake in TS error, click on the link and follow the instructions.

If you need to check if a value exists in an enum, click on the following article.

# Additional Resources

You can learn more about the related topics by checking out the following tutorials:

I wrote a book in which I share everything I know about how to become a better, more efficient programmer.

Источник

Switch Statement in Typescript

The Typescript switch statement (or switch case statement) evaluates a given expression. It then matches the result of that expression with the values in the case clause. If it finds a match, then it executes the statements associated with that matching case clause. It also executes the statements in case ‘s that follow the matching case . You can break out of a switch using the break statement or using the return statement

Switch Case Syntax

The Syntax of the Switch Statement in Typescript is as follows.

The switch statement starts with keyword switch and expression in parentheses. The Typescript evaluates the expression (switch expression) and compares it with values in the case clause.

We follow switch expression with curly braces with one or more case clauses and an optional default clause.

Each case clause must have a value terminated by a colon. The default clause must not have a value. Within the individual case clause, we may write several statements

How it works

First, the switch expression evaluates its expression.

It then starts to compare the result of the expression with each case value.

When it finds a match, the switch statement then executes the statements starting from the code associated with the case clause that matches. It continues to execute the statements until it reaches

  1. end of the switch or
  2. it encounters a break statement or
  3. it encounters a return statement

Only the first match is considered, even if there is more than one match.

If none of the case values matches with the expression result, then it will start to execute the statements starting from the code associated with the default clause.

By convention, the default clause is the last clause, but it does not need to be so.

Switch Examples

Using Switch

In the following example, the expression operation matches the case clause — . Hence the switch executes the code associated with that case clause. When it encounters the break , it breaks out of the switch.

Источник

Оцените статью