Monday, November 18, 2024
Google search engine
HomeLanguagesJavascriptWhat is an unknown type and when to use it in TypeScript...

What is an unknown type and when to use it in TypeScript ?

In Typescript, any value can be assigned to unknown, but without a type assertion, unknown can’t be assigned to anything but itself and any. Similarly, no operations on an unknown are allowed without first asserting or restricting it down to a more precise type.  similar to any, we can assign any value to the unknown, just like any other; even so, unlike any, we can’t access any properties on unknown values, nor can we call or construct them. In addition, unknown values can only be assigned to unknown or any.

Unknown type is used to make our code type-safe. when we use the unknown type we have to write extra code but finally, our code will be type-safe. type safety is nothing but the prevention of type errors.

Let’s understand when to use unknown types and when not to use with the help of the following examples.

Example 1: When variables of other value types are assigned to unknown.

In this example, we assign values of different types to the unknown variable. we can see that it doesn’t raise any error. unknown type lies on the top when it comes to variable types in Typescript.

Javascript




<script>
    let val: unknown;
    console.log(val);
    val = true;
    console.log(val);
    val = 7;
    console.log(val);
    val = "neveropen for neveropen";
    console.log(val);
    val = [1, 2, 3, 4];
    console.log(val);
    val = { name: "rachel" };
    console.log(val);
    val = Math.random();
    console.log(val);
    val = null;
    console.log(val);
    val = undefined;
    console.log(val);
</script>


Output:

undefined
true
7
neveropen for neveropen
[ 1, 2, 3, 4 ]
{ name: 'rachel' }
0.776446663785197
null
undefined

Example 2: unknown is assigned to unknown and other type values

As it’s given in the introduction, an unknown type variable can only be assigned to another unknown type variable or a variable of type any. unknown type is displayed as “undefined”.

Javascript




<script>
    let a: unknown;
    console.log(a);
    let b: unknown = a;
    console.log(b);
    let c: any = a;
    console.log(c);
</script>


Output:

undefined
undefined
undefined

Example 3: In this example, we tried to assign an unknown type value to a variable of type number, an error is raised.

Javascript




<script>
    let unknown: unknown;
    let num: number = unknown; // Error
    console.log(num);
</script>


Output:

error TS2322: Type 'unknown' is not assignable to type 'number'.
let num: number = a; // Error

 Example 4: In typescript, we can’t perform operations on unknown type values. Object type operations cannot be performed on unknown type values. 

Javascript




<script>
    let unknown_val: unknown;
    unknown_val.split("");
    console.log(unknown_val);
</script>


Output:

error TS2339: Property 'split' does not exist on type 'unknown'.

Whether you’re preparing for your first job interview or aiming to upskill in this ever-evolving tech landscape, neveropen Courses are your key to success. We provide top-quality content at affordable prices, all geared towards accelerating your growth in a time-bound manner. Join the millions we’ve already empowered, and we’re here to do the same for you. Don’t miss out – check it out now!

RELATED ARTICLES

Most Popular

Recent Comments