Esprima 3.0.5

:mega: Important notices
If you are upgrading from an older version, please note that version 3 ships with numerous breaking changes to the public API because virtually all areas of the library have been revised.
Documentation of the previous major version is available here.

Build NuGet MyGet

Esprima .NET (BSD license) is a .NET port of the esprima.org project. It is a standard-compliant ECMAScript parser (also popularly known as JavaScript).

Features

API

Esprima can be used to perform lexical analysis (tokenization) or syntactic analysis (parsing) of a JavaScript program.

A simple C# example:

var parser = new JavaScriptParser();
var program = parser.ParseScript("const answer = 42");

You can control the behavior of the parser by initializing and passing a ParserOptions to the parser's constructor. (For the available options, see the XML documentation of the ParserOptions class.)

Instead of ParseScript, you may use ParseModule or ParseExpression to make the parser treat the input as an ES6 module or as a plain JavaScript expression respectively.

In case the input is syntactically correct, each of these methods returns the root node of the resulting abstract syntax tree (AST), which you can freely analyze or transform. The library provides the AstVisitor and AstRewriter visitor classes to help you with such tasks.

When the input contains a severe syntax error, a ParserException is thrown. By catching it you can get details about the error. There are syntax errors though which can be tolerated by the parser. Such errors are ignored by default. You can record them by setting ParserOptions.ErrorHandler to an instance of CollectingErrorHandler. Alternatively, you can set ParserOptions.Tolerant to false to make the parser throw exceptions also in the case of tolerable syntax errors.

The library is able to write the AST (except for comments) back to JavaScript code:

var code = program.ToJavaScriptString(format: true);

It is also possible to serialize the AST into a JSON representation:

var astJson = program.ToJsonString(indent: "    ");

Considering the example above this call will return the following JSON:

{
    "type": "Program",
    "body": [
        {
            "type": "VariableDeclaration",
            "declarations": [
                {
                    "type": "VariableDeclarator",
                    "id": {
                        "type": "Identifier",
                        "name": "answer"
                    },
                    "init": {
                        "type": "Literal",
                        "value": 42,
                        "raw": "42"
                    }
                }
            ],
            "kind": "const"
        }
    ],
    "sourceType": "script",
    "strict": false
}

Benchmarks

Here is a list of common JavaScript libraries and the time it takes to parse them, compared to the time it took for the same script using the original Esprima in Chrome.

Script Size Esprima .NET (.NET 6) Esprima (Chrome 116)
underscore-1.5.2 43 KB 1.0 ms 1.4 ms
backbone-1.1.0 59 KB 1.2 ms 1.6 ms
mootools-1.4.5 157 KB 5.2 ms 7.1 ms
jquery-1.9.1 262 KB 6.6 ms 7.9 ms
yui-3.12.0 330 KB 4.6 ms 6.9 ms
jquery.mobile-1.4.2 442 KB 10.0 ms 17.7 ms
angular-1.2.5 702 KB 8.5 ms 15.1 ms

Showing the top 20 packages that depend on Esprima.

Packages Downloads
Jint
Javascript interpreter for .NET.
320
Jint
Javascript interpreter for .NET which provides full ECMA 5.1 compliance.
23
Jint
Javascript interpreter for .NET.
22
Jint
Javascript interpreter for .NET which provides full ECMA 5.1 compliance.
22
Jint
Javascript interpreter for .NET.
21
Jint
Javascript interpreter for .NET which provides full ECMA 5.1 compliance.
20
Jint
Javascript interpreter for .NET.
20

.NET Framework 4.6.2

.NET Standard 2.0

.NET Standard 2.1

  • No dependencies.

Version Downloads Last updated
3.0.5 17 04/24/2024
3.0.4 257 02/01/2024
3.0.3 17 02/01/2024
3.0.2 13 11/16/2023
3.0.1 14 10/11/2023
3.0.0 18 10/10/2023
3.0.0-rc-04 19 08/24/2023
3.0.0-rc-03 16 11/02/2023
3.0.0-rc-02 19 06/05/2023
3.0.0-rc-01 22 06/05/2023
3.0.0-beta-9 21 06/05/2023
3.0.0-beta-8 19 06/05/2023
3.0.0-beta-7 22 06/05/2023
3.0.0-beta-6 20 06/05/2023
3.0.0-beta-5 20 06/05/2023
3.0.0-beta-4 19 06/05/2023
3.0.0-beta-3 19 06/05/2023
3.0.0-beta-2 25 06/05/2023
3.0.0-beta-10 21 06/05/2023
3.0.0-beta-1 22 06/05/2023
2.1.3 22 06/05/2023
2.1.2 21 06/05/2023
2.1.1 20 06/05/2023
2.1.0 21 06/05/2023
2.0.5 20 06/05/2023
2.0.4 22 06/05/2023
2.0.3 19 06/05/2023
2.0.2 21 06/05/2023
2.0.1 23 06/05/2023
2.0.0 20 06/05/2023
2.0.0-beta-1339 24 06/05/2023
2.0.0-beta-1338 22 06/05/2023
2.0.0-beta-1328 22 06/05/2023
2.0.0-beta-1317 20 06/05/2023
2.0.0-beta-1311 22 06/05/2023
2.0.0-beta-1303 23 06/05/2023
2.0.0-beta-1302 18 06/05/2023
2.0.0-beta-1298 21 06/05/2023
2.0.0-beta-1295 25 06/05/2023
2.0.0-beta-1292 22 06/05/2023
1.0.1270 18 06/05/2023
1.0.1258 19 06/05/2023
1.0.1251 24 06/05/2023
1.0.1246 19 06/05/2023
1.0.0-beta-1202 21 06/05/2023
1.0.0-beta-1186 23 06/05/2023
1.0.0-beta-1178 23 06/05/2023
1.0.0-beta-1070 22 06/05/2023
1.0.0-beta-1051 18 06/05/2023
1.0.0-beta-1036 28 06/05/2023
1.0.0-beta-1026 24 06/05/2023
1.0.0-beta-1023 22 06/05/2023
1.0.0-beta-1012 19 06/05/2023
1.0.0-beta-001 22 06/05/2023
1.0.0-alpha-003 16 06/05/2023
1.0.0-alpha-002 20 06/05/2023
1.0.0-alpha-001 22 06/05/2023