<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Bhushan Shah</title>
    <description>The latest articles on DEV Community by Bhushan Shah (@bhushanshahdev).</description>
    <link>https://dev.to/bhushanshahdev</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F546115%2F3912b234-e9f9-4b38-a62b-6badae4c9c74.jpeg</url>
      <title>DEV Community: Bhushan Shah</title>
      <link>https://dev.to/bhushanshahdev</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/bhushanshahdev"/>
    <language>en</language>
    <item>
      <title>undefined vs. null</title>
      <dc:creator>Bhushan Shah</dc:creator>
      <pubDate>Mon, 01 Mar 2021 01:47:52 +0000</pubDate>
      <link>https://dev.to/bhushanshahdev/undefined-vs-null-575e</link>
      <guid>https://dev.to/bhushanshahdev/undefined-vs-null-575e</guid>
      <description>&lt;p&gt;Have you ever wondered why JavaScript (and TypeScript) has two distinct keywords — &lt;code&gt;undefined&lt;/code&gt; and &lt;code&gt;null&lt;/code&gt; — that kind of feel similar? Most other languages have a &lt;code&gt;null&lt;/code&gt; (or equivalent) keyword. It's usually a value you can assign to a variable, and it indicates an "empty" value, or a "sentinel" value. It works similarly in JavaScript too. But then why does JavaScript have another similar keyword called &lt;code&gt;undefined&lt;/code&gt;? What's the difference between the two? How do we decide if we should use &lt;code&gt;undefined&lt;/code&gt; or &lt;code&gt;null&lt;/code&gt;? How does the usage of &lt;code&gt;undefined&lt;/code&gt; or &lt;code&gt;null&lt;/code&gt; impact types? This post will try to provide answers to these questions.&lt;/p&gt;

&lt;p&gt;Let's get into it.&lt;/p&gt;

&lt;p&gt;The main conceptual difference between variables with value &lt;code&gt;null&lt;/code&gt; and variables with value &lt;code&gt;undefined&lt;/code&gt; is the intention of the programmer. The rule of thumb I like to follow is &lt;strong&gt;&lt;code&gt;undefined&lt;/code&gt; is for unintentionally empty values, while &lt;code&gt;null&lt;/code&gt; is for intentionally empty values.&lt;/strong&gt; This means that any variable which has not been assigned a value has the value &lt;code&gt;undefined&lt;/code&gt;, whereas if a programmer wanted to assign an "empty" value to a variable, they would typically assign it &lt;code&gt;null&lt;/code&gt;, which is interpreted as a sentinel value.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;foo&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="c1"&gt;// `foo` is `undefined` because it's not set&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;foo&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// undefined&lt;/span&gt;

&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;bar&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="c1"&gt;// `bar` is `null` because it is explicitly set to `null`&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;bar&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// null&lt;/span&gt;

&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;obj&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;baz&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;undefined&lt;/span&gt; &lt;span class="p"&gt;};&lt;/span&gt;
&lt;span class="c1"&gt;// `obj['baz']` is `undefined` because it is explicitly set to `undefined`&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;obj&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;baz&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;]);&lt;/span&gt; &lt;span class="c1"&gt;// undefined&lt;/span&gt;
&lt;span class="c1"&gt;// `obj['qux']` is `undefined` because it's not set&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;obj&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;qux&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;]);&lt;/span&gt; &lt;span class="c1"&gt;// undefined&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h3&gt;
  
  
  Wait, this is too confusing...
&lt;/h3&gt;

&lt;p&gt;Let's go through an example to see what this means.&lt;/p&gt;

&lt;p&gt;Suppose we are writing some router logic, and want to add a &lt;code&gt;Cache-Control&lt;/code&gt; header to the response if some flag &lt;code&gt;isCachingOn&lt;/code&gt; was &lt;code&gt;true&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;We could do this:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;headers&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{};&lt;/span&gt;
&lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;isCachingOn&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;headers&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;Cache-Control&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;]:&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;max-age=31536000&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="nx"&gt;res&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="kd"&gt;set&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;headers&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;But we could also rewrite this more succinctly as&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="nx"&gt;res&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="kd"&gt;set&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
  &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;Cache-Control&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;isCachingOn&lt;/span&gt; &lt;span class="p"&gt;?&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;max-age=31536000&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt; &lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;undefined&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Both these code snippets are equivalent. In both cases, if &lt;code&gt;isCachingOn&lt;/code&gt; is &lt;code&gt;false&lt;/code&gt;, we don't set the value of the &lt;code&gt;Cache-Control&lt;/code&gt; property, which means we just end up passing &lt;code&gt;{}&lt;/code&gt; as the argument to &lt;code&gt;res.set()&lt;/code&gt;. Generally, setting something to &lt;code&gt;undefined&lt;/code&gt; has the impact of "not setting" it (or "unsetting" it if already set).&lt;/p&gt;

&lt;p&gt;But what if we set it to &lt;code&gt;null&lt;/code&gt; instead?&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="nx"&gt;res&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="kd"&gt;set&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt;
  &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;Cache-Control&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;isCachingOn&lt;/span&gt; &lt;span class="p"&gt;?&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;max-age=31536000&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt; &lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;
&lt;span class="p"&gt;});&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Is this the same as the previous two snippets?&lt;/p&gt;

&lt;p&gt;The answer is no.&lt;/p&gt;

&lt;p&gt;In this case, if &lt;code&gt;isCaching&lt;/code&gt; is &lt;code&gt;false&lt;/code&gt;, we actually set the value of the &lt;code&gt;Cache-Control&lt;/code&gt; property to &lt;code&gt;null&lt;/code&gt;. This is not the same as "not setting" it. We are &lt;em&gt;explicitly&lt;/em&gt; setting it to a &lt;code&gt;null&lt;/code&gt; value. We end up passing &lt;code&gt;{ 'Cache-Control': null }&lt;/code&gt; to &lt;code&gt;res.set()&lt;/code&gt;. Depending on what router framework we are using, this may very well work the same as the &lt;code&gt;undefined&lt;/code&gt; example above, if the framework is smart enough to ignore headers whose value is set to &lt;code&gt;null&lt;/code&gt;. However, from the perspective of the programming language, both are different, and this difference may be much more important in some cases.&lt;/p&gt;




&lt;h3&gt;
  
  
  What about types though?
&lt;/h3&gt;

&lt;p&gt;Okay, let's talk about types. What's the type of variables whose value is &lt;code&gt;undefined&lt;/code&gt; or &lt;code&gt;null&lt;/code&gt;? Do they even have a type? Can we assign &lt;code&gt;undefined&lt;/code&gt; or &lt;code&gt;null&lt;/code&gt; to a variable of &lt;code&gt;string&lt;/code&gt; or &lt;code&gt;number&lt;/code&gt; or &lt;code&gt;boolean&lt;/code&gt; type?&lt;/p&gt;

&lt;p&gt;In JavaScript, we can get the runtime type of a variable by using the &lt;code&gt;typeof&lt;/code&gt; keyword. Depending on the actual value of the variable, we will receive one of the following strings back:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;&lt;code&gt;"string"&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;"number"&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;"boolean"&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;"bigint"&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;"symbol"&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;"object"&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;"function"&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;&lt;code&gt;"undefined"&lt;/code&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;As you can see, &lt;code&gt;"undefined"&lt;/code&gt; is one of the ECMAScript types. And as you can guess, we get this value when we try to use &lt;code&gt;typeof&lt;/code&gt; with a variable whose value is &lt;code&gt;undefined&lt;/code&gt; (i.e. it hasn't been set yet, or has been unset explicitly by setting it to &lt;code&gt;undefined&lt;/code&gt;).&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;foo&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="k"&gt;typeof&lt;/span&gt; &lt;span class="nx"&gt;foo&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// "undefined"&lt;/span&gt;
&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;bar&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;42&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="nx"&gt;bar&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kc"&gt;undefined&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="k"&gt;typeof&lt;/span&gt; &lt;span class="nx"&gt;bar&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// "undefined"&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;So far so good. But what about &lt;code&gt;null&lt;/code&gt;? Why isn't there a &lt;code&gt;"null"&lt;/code&gt; type. What happens if we use &lt;code&gt;typeof&lt;/code&gt; with a variable whose value is &lt;code&gt;null&lt;/code&gt;? The answer may surprise you.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;foo&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="k"&gt;typeof&lt;/span&gt; &lt;span class="nx"&gt;foo&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// "object"&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Wait, but doesn't type &lt;code&gt;"object"&lt;/code&gt; imply that the variable is an object? Well yes, but actually no. As it turns out, in JavaScript, the type of &lt;code&gt;null&lt;/code&gt; variables is also &lt;code&gt;"object"&lt;/code&gt;. This is a bug since the early days of JavaScript, and unfortunately can't be fixed. You can read more about it &lt;a href="https://2ality.com/2013/10/typeof-null.html"&gt;here&lt;/a&gt;.&lt;/p&gt;




&lt;h3&gt;
  
  
  Wait, isn't there a &lt;code&gt;null&lt;/code&gt; type in TypeScript?
&lt;/h3&gt;

&lt;p&gt;That's correct. TypeScript does have a &lt;code&gt;null&lt;/code&gt; type. However, this is a compile-time type, used for compile-time type-checking. At runtime however, when the TypeScript code has been compiled to JavaScript, there is no &lt;code&gt;null&lt;/code&gt; type. Instead, you only have the aforementioned runtime types.&lt;/p&gt;

&lt;p&gt;Does this mean that we can't assign &lt;code&gt;null&lt;/code&gt; to variables whose compile-time type is something else, like &lt;code&gt;string&lt;/code&gt; or &lt;code&gt;boolean&lt;/code&gt; or &lt;code&gt;number&lt;/code&gt;? What if we have a function that accepts a parameter of type &lt;code&gt;string&lt;/code&gt;, but we pass it an argument of type &lt;code&gt;null&lt;/code&gt; instead?&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kr"&gt;string&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Testing debug log...&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// Does this work?&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;The answer is, &lt;em&gt;it depends&lt;/em&gt;. More specifically, it depends on whether or not we have strict mode turned on. Even more specifically, it depends on if we have set &lt;a href="https://www.typescriptlang.org/tsconfig#strictNullChecks"&gt;&lt;code&gt;strictNullChecks&lt;/code&gt;&lt;/a&gt; to &lt;code&gt;true&lt;/code&gt; in our compiler options.&lt;/p&gt;

&lt;p&gt;If we have &lt;code&gt;strictNullChecks&lt;/code&gt; set to &lt;code&gt;false&lt;/code&gt;, the TypeScript compiler will happily compile this code to JavaScript. But if we have &lt;code&gt;strictNullChecks&lt;/code&gt; set to &lt;code&gt;true&lt;/code&gt;, compilation will fail with the following error:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Argument of type 'null' is not assignable to parameter of type 'string'.
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Note that if this compiler option is turned off, apart from &lt;code&gt;null&lt;/code&gt;, it also allows us to assign &lt;code&gt;undefined&lt;/code&gt; to variables of other types.&lt;/p&gt;

&lt;p&gt;If we do have strict mode turned on like a good programmer, and we don't know if a variable can be &lt;code&gt;null&lt;/code&gt; at runtime, we can use union types to allow the &lt;code&gt;null&lt;/code&gt; type too.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight typescript"&gt;&lt;code&gt;&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kr"&gt;string&lt;/span&gt; &lt;span class="o"&gt;|&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Testing debug log...&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="nx"&gt;debug&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// No problem!&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h3&gt;
  
  
  How do I check if a variable is &lt;code&gt;undefined&lt;/code&gt; or &lt;code&gt;null&lt;/code&gt;?
&lt;/h3&gt;

&lt;p&gt;This is a very common use case, and one where many programmers make mistakes. Often we want to add defensive checks inside functions which check if the argument passed is defined. Maybe we want to handle &lt;code&gt;null&lt;/code&gt; arguments separately. How should we check if the argument is in fact &lt;code&gt;undefined&lt;/code&gt; or &lt;code&gt;null&lt;/code&gt;? &lt;/p&gt;

&lt;p&gt;In JavaScript, to check if a variable is &lt;code&gt;undefined&lt;/code&gt;, we can do one of two things:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;foo&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;bar&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;foo&lt;/span&gt; &lt;span class="o"&gt;===&lt;/span&gt; &lt;span class="kc"&gt;undefined&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;foo is undefined&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// "foo is undefined"&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="k"&gt;typeof&lt;/span&gt; &lt;span class="nx"&gt;bar&lt;/span&gt; &lt;span class="o"&gt;===&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;undefined&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;bar is undefined&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// "bar is undefined"&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;We can either check if the value of the variable is &lt;code&gt;undefined&lt;/code&gt;, or check that its type is &lt;code&gt;"undefined"&lt;/code&gt;. These two are equivalent, because &lt;code&gt;undefined&lt;/code&gt; is the only value which has a runtime type of &lt;code&gt;"undefined"&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;Unfortunately, this same tactic of checking the type will not work with &lt;code&gt;null&lt;/code&gt;, because its type is &lt;code&gt;"object"&lt;/code&gt;, which is not unique to &lt;code&gt;null&lt;/code&gt;. So to check if a variable is &lt;code&gt;null&lt;/code&gt;, we must explicitly check its value.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;foo&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;foo&lt;/span&gt; &lt;span class="o"&gt;===&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;foo is null&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt; &lt;span class="c1"&gt;// "foo is null"&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;What about TypeScript though? TypeScript has a &lt;code&gt;null&lt;/code&gt; type right?&lt;/p&gt;

&lt;p&gt;Yes, but as mentioned above, it's only a compile-time type. In most cases, we don't even need to add such defensive checks in TypeScript, since the compile-time type checking does this for us if we have strict mode on. We won't be able to pass arguments of type &lt;code&gt;null&lt;/code&gt; or &lt;code&gt;undefined&lt;/code&gt; if the corresponding parameter type is something else.&lt;/p&gt;

&lt;p&gt;However, there are cases when we aren't sure what type of argument we might receive (for example, if we are dealing with something that has been sent over the wire), and we do want to add runtime defensive checks. In that case, we can include the same checks as above, which will be included in the compiled JavaScript, and execute at runtime.&lt;/p&gt;

</description>
      <category>typescript</category>
      <category>javascript</category>
    </item>
  </channel>
</rss>
