Home > Web Front-end > JS Tutorial > Detailed explanation of the pitfalls of JavaScript syntax for {} processing_Basic knowledge

Detailed explanation of the pitfalls of JavaScript syntax for {} processing_Basic knowledge

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Release: 2016-05-16 16:46:18
Original
1390 people have browsed it

Everyone knows how pitiful the syntax of JavaScript is.

Let’s take a picture first

Detailed explanation of the pitfalls of JavaScript syntax for {} processing_Basic knowledge

The code is as follows:

Copy code The code is as follows:

{} []; // 0
[ ] {}; // "[object Object]"
{} [] == [] {}; // false
({} [] == [] {}); // true

Such a painful syntax pit is probably only found in weird things like JavaScript.

I believe that most children who do not study JavaScript compilers cannot understand it at all. (At least I find it incredible)

Later, I went to visit my mother for a special visit, and I suddenly realized it!

Next, let’s take a look at this code:

Copy code The code is as follows:

{
a: 1
}

I believe that most children's shoes will think that this is an object direct quantity at first glance.

What about this code?

Copy code The code is as follows:

{
var a = 1;
}

Will the browser prompt a syntax error?

Obviously not! If we think about it carefully, we will realize that this is a statement block.

Copy code The code is as follows:

if (isNumber) {
var a = 1 ;
}


At this point, if you are keen, you may have discovered: there will be ambiguity in JavaScript starting with {.

How does the JavaScript compiler deal with this ambiguity?

To solve this problem, ECMA’s method is very simple and crude: during grammar parsing, if a statement starts with "{", it will only be interpreted as a statement block.

This is really a cheating way to deal with it!

Since they are all statement blocks, why does {a:1} have no grammatical errors?

In fact, here, a is understood by the parser as a tag. Labels are used with break and continue statements to make directional jumps.

Therefore, writing like this will throw an exception:

Copy code The code is as follows:

{
a: function () {}
}

Because function () {} is not a function declaration, nor a function expression.

At this point, everyone should have a basic idea of ​​the strange processing of {}. Let’s look back at the sentences mentioned at the beginning of the article:

Copy code The code is as follows:

{} []; // 0
[ ] {}; // "[object Object]"
{} [] == [] {}; // false
({} [] == [] {}); // true

The first one, because {} is a statement block, the code can be understood as:

Copy code The code is as follows:

if (1) {}
[]

So the return value is 0 .

Second, since {} is not at the beginning of the statement, it is a normal object direct quantity. The empty array and the empty object are added directly and "[object Object]" is returned.

Understood the first and second items, the third item no longer needs explanation.

The fourth one, because it starts with (), the first {} is parsed as an object literal, so the two formulas are equal and return true.

Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template