JavaScript's unreliable undefined

JavaScript's unreliable undefined

undefined In JavaScript, if we want to determine whether a value is undefined, we usually write:

if(a === undefined){ //code}

However, undefined in JavaScript is not reliable. Let's try to write a function like this:

function test(a) {
  var undefined = 1;
  console.log(undefined); // => 1
  if(a === undefined) {
    // ...
  }
}

As you can see, undefined is easily changed to 1, which makes our subsequent understanding of undefined ambiguous. Therefore, in JavaScript, it is risky to interpret undefined directly as "undefined" because the identifier may be tampered with.

Before ES5, the global undefined can also be modified. In ES5, this identifier is designed to be a read-only identifier. If your current browser is not too old, you can enter the following statement in the console to test it:

undefined = 1;
console.log(undefined); // => undefined

Now we can clearly see that the identifier undefined does not really reflect "undefined", so we have to obtain this semantics through other means. Fortunately, JavaScript also provides the void operator, which evaluates the specified expression and returns the trusted undefined:

void expression

The most common usage is to obtain undefined through the following operation, and the operation cost is the smallest when the expression is 0:

void 0;
// or
void(0);

All places where undefined is needed are replaced by void 0

Of course, there is another way to get undefined: those who have read the jQuery source code should know the immediately executed function in it:

(function(window,undefined) {
    // ...
})(window)

In this function, we did not pass it the second parameter (the parameter name is undefined), so the value of the second parameter will be considered "undefined". Therefore, in this way, all undefined in the scope of this function are trusted undefined.

The above is the details of JavaScript's unreliable undefined. For more information about JavaScript's unreliable undefined, please pay attention to other related articles on 123WORDPRESS.COM!

You may also be interested in:
  • 7 tips for dealing with undefined JavaScript values
  • JavaScript undefined and null difference example analysis
  • Analysis of null and undefined usage in JavaScript
  • The essence of undefined in javascript
  • Solution to the problem that the return value of showModalDialog function in JS Chrome browser is undefined
  • A brief analysis of undefined and null in the Javascript type system
  • JavaScript type system - a comprehensive understanding of undefined and null
  • Javascript Basics_Simple comparison of undefined and null values
  • JavaScript must know (Part 2) null and undefined
  • Distinguishing Undefined and null types in JavaScript

<<:  An example of installing MySQL on Linux and configuring external network access

>>:  5 Easy Ways to Free Up Space on Ubuntu

Recommend

MySQL 8.0.17 installation and simple configuration tutorial under macOS

If you don’t understand what I wrote, there may b...

Detailed installation process of mysql5.7.21 under win10

This article shares the installation of MySQL 5.7...

JS implements random roll call system

Use JS to implement a random roll call system for...

Detailed explanation of the code for implementing linear gradients with CSS3

Preface The gradient of the old version of the br...

vue_drf implements SMS verification code

Table of contents 1. Demand 1. Demand 2. SDK para...

How to add Lua module to Nginx

Install lua wget http://luajit.org/download/LuaJI...

Better looking CSS custom styles (title h1 h2 h3)

Rendering Commonly used styles in Blog Garden /*T...

MySQL not null constraint case explanation

Table of contents Set a not null constraint when ...

Do you know how many connections a Linux server can handle?

Preface First, let's see how to identify a TC...

mysql workbench installation and configuration tutorial under centOS

This article shares the MySQL Workbench installat...

How to implement a lucky wheel game in WeChat applet

I mainly introduce how to develop a lucky wheel g...