AngleSharp 1.5.1

logo

AngleSharp

CI GitHub Tag NuGet Count Issues Open

StackOverflow Questions CLA Assistant

AngleSharp is a .NET library that gives you the ability to parse angle bracket based hyper-texts like HTML, SVG, and MathML. XML without validation is also supported by the library. An important aspect of AngleSharp is that CSS can also be parsed. The included parser is built upon the official W3C specification. This produces a perfectly portable HTML5 DOM representation of the given source code and ensures compatibility with results in evergreen browsers. Also standard DOM features such as querySelector or querySelectorAll work for tree traversal.

:zap: Migrating from AngleSharp 0.9 to AngleSharp 0.10 or later (incl. 1.0)? Look at our migration documentation. :zap:

Key Features

  • Portable (using .NET Standard 2.0)
  • Standards conform (works exactly as evergreen browsers)
  • Great performance (outperforms similar parsers in most scenarios)
  • Extensible (extend with your own services)
  • Useful abstractions (type helpers, jQuery like construction)
  • Fully functional DOM (all the lists, iterators, and events you know)
  • Form submission (easily log in everywhere)
  • Navigation (a BrowsingContext is like a browser tab - control it from .NET!).
  • LINQ enhanced (use LINQ with DOM elements, naturally without wrappers)

The advantage over similar libraries like HtmlAgilityPack is that the exposed DOM is using the official W3C specified API, i.e., that even things like querySelectorAll are available in AngleSharp. Also the parser uses the HTML 5.1 specification, which defines error handling and element correction. The AngleSharp library focuses on standards compliance, interactivity, and extensibility. It is therefore giving web developers working with C# all possibilities as they know from using the DOM in any modern browser.

The performance of AngleSharp is quite close to the performance of browsers. Even very large pages can be processed within milliseconds. AngleSharp tries to minimize memory allocations and reuses elements internally to avoid unnecessary object creation.

Simple Demo

The simple example will use the website of Wikipedia for data retrieval.

var config = Configuration.Default.WithDefaultLoader();
var address = "https://en.wikipedia.org/wiki/List_of_The_Big_Bang_Theory_episodes";
var context = BrowsingContext.New(config);
var document = await context.OpenAsync(address);
var cellSelector = "tr.vevent td:nth-child(3)";
var cells = document.QuerySelectorAll(cellSelector);
var titles = cells.Select(m => m.TextContent);

Or the same with explicit types:

IConfiguration config = Configuration.Default.WithDefaultLoader();
string address = "https://en.wikipedia.org/wiki/List_of_The_Big_Bang_Theory_episodes";
IBrowsingContext context = BrowsingContext.New(config);
IDocument document = await context.OpenAsync(address);
string cellSelector = "tr.vevent td:nth-child(3)";
IHtmlCollection<IElement> cells = document.QuerySelectorAll(cellSelector);
IEnumerable<string> titles = cells.Select(m => m.TextContent);

In the example we see:

  • How to setup the configuration for supporting document loading
  • Asynchronously get the document in a new context using the configuration
  • Performing a query to get all cells with the content of interest
  • The whole DOM supports LINQ queries

Every collection in AngleSharp supports LINQ statements. AngleSharp also provides many useful extension methods for element collections that cannot be found in the official DOM.

Supported Platforms

AngleSharp has been created as a .NET Standard 2.0 compatible library. This includes, but is not limited to:

  • .NET Core (2.0 and later)
  • .NET Framework (4.6.2 and later)
  • Xamarin.Android (7.0 and 8.0)
  • Xamarin.iOS (10.0 and 10.14)
  • Xamarin.Mac (3.0 and 3.8)
  • Mono (4.6 and 5.4)
  • UWP (10.0 and 10.0.16299)
  • Unity (2018.1)

Documentation

The documentation of AngleSharp is located in the docs folder. More examples, best-practices, and general information can be found there. The documentation also contains a list of frequently asked questions.

More information is also available by following some of the hyper references mentioned in the Wiki. In-depth articles will be published on the CodeProject, with links being placed in the Wiki at GitHub.

Use-Cases

  • Parsing HTML (incl. fragments)
  • Parsing CSS (incl. selectors, declarations, ...)
  • Constructing HTML (e.g., view-engine)
  • Minifying CSS, HTML, ...
  • Querying document elements
  • Crawling information
  • Gathering statistics
  • Web automation
  • Tools with HTML / CSS / ... support
  • Connection to page analytics
  • HTML / DOM unit tests
  • Automated JavaScript interaction
  • Testing other concepts, e.g., script engines
  • ...

Vision

The project aims to bring a solid implementation of the W3C DOM for HTML, SVG, MathML, and CSS to the CLR - all written in C#. The idea is that you can basically do everything with the DOM in C# that you can do in JavaScript (plus, of course, more).

Most parts of the DOM are included, even though some may still miss their (fully specified / correct) implementation. The goal for v1.0 is to have all practically relevant parts implemented according to the official W3C specification (with useful extensions by the WHATWG).

The API is close to the DOM4 specification, however, the naming has been adjusted to apply with .NET conventions. Nevertheless, to make AngleSharp really useful for, e.g., a JavaScript engine, attributes have been placed on the corresponding interfaces (and methods, properties, ...) to indicate the status of the field in the official specification. This allows automatic generation of DOM objects with the official API.

This is a long-term project which will eventually result in a state of the art parser for the most important angle bracket based hyper-texts.

Our hope is to build a community around web parsing and libraries from this project. So far we had great contributions, but that goal was not fully achieved. Want to help? Get in touch with us!

Participating in the Project

If you know some feature that AngleSharp is currently missing, and you are willing to implement the feature, then your contribution is more than welcome! Also if you have a really cool idea - do not be shy, we'd like to hear it.

If you have an idea how to improve the API (or what is missing) then posts / messages are also welcome. For instance there have been ongoing discussions about some styles that have been used by AngleSharp (e.g., HTMLDocument or HtmlDocument) in the past. In the end AngleSharp stopped using HTMLDocument (at least visible outside of the library). Now AngleSharp uses names like IDocument, IHtmlElement and so on. This change would not have been possible without such fruitful discussions.

The project is always searching for additional contributors. Even if you do not have any code to contribute, but rather an idea for improvement, a bug report or a mistake in the documentation. These are the contributions that keep this project active.

Live discussions can take place in our Gitter chat, which supports using GitHub accounts.

More information is found in the contribution guidelines. All contributors can be found in the CONTRIBUTORS file.

This project has also adopted the code of conduct defined by the Contributor Covenant to clarify expected behavior in our community.

For more information see the .NET Foundation Code of Conduct.

Funding / Support

If you use AngleSharp frequently, but you do not have the time to support the project by active participation you may still be interested to ensure that the AngleSharp projects keeps the lights on.

See the related GitHub issue for more information.

Development

AngleSharp is written in the most recent version of C# and thus requires Roslyn as a compiler. Using an IDE like Visual Studio 2019+ is recommended on Windows. Alternatively, VSCode (with OmniSharp or another suitable Language Server Protocol implementation) should be the tool of choice on other platforms.

The code tries to be as clean as possible. Notably the following rules are used:

  • Use braces for any conditional / loop body
  • Use the -Async suffixed methods when available
  • Use VIP ("Var If Possible") style (in C++ called AAA: Almost Always Auto) to place types on the right

More important, however, is the proper usage of tests. Any new feature should come with a set of tests to cover the functionality and prevent regression.

Changelog

A very detailed changelog exists. If you are just interested in major releases then have a look at the GitHub releases.

.NET Foundation

This project is supported by the .NET Foundation.

License

AngleSharp is released using the MIT license. For more information see the license file.

Showing the top 20 packages that depend on AngleSharp.

Packages Downloads
AngleSharp.Css
Extends the CSSOM from the core AngleSharp library.
38
AngleSharp.Css
Extends the CSSOM from the core AngleSharp library.
35
AngleSharp.Css
Extends the CSSOM from the core AngleSharp library.
33
HtmlSanitizer
Cleans HTML from constructs that can be used for cross-site scripting (XSS)
33
AngleSharp.Css
Extends the CSSOM from the core AngleSharp library.
32
AngleSharp.Css
Extends the CSSOM from the core AngleSharp library.
31
AngleSharp.Css
Extends the CSSOM from the core AngleSharp library.
30

.NET Standard 2.0

.NET Framework 4.6.2

.NET Framework 4.7.2

.NET 6.0

  • No dependencies.

.NET 7.0

  • No dependencies.

.NET 8.0

  • No dependencies.

.NET 10.0

  • No dependencies.

Version Downloads Last updated
1.5.1 1 06/15/2026
1.5.1-beta.530 5 06/10/2026
1.5.0 8 06/08/2026
1.5.0-beta.529 4 06/10/2026
1.5.0-beta.526 10 06/10/2026
1.4.1-beta.525 11 06/10/2026
1.4.1-beta.523 32 04/20/2026
1.4.1-beta.518 28 04/02/2026
1.4.1-beta.509 27 03/31/2026
1.4.1-beta.508 22 03/31/2026
1.4.1-beta.506 40 12/17/2025
1.4.1-beta.505 26 12/12/2025
1.4.1-beta.504 34 12/14/2025
1.4.1-beta.502 27 12/13/2025
1.4.0 24 12/15/2025
1.4.0-beta.499 38 12/15/2025
1.4.0-beta.497 30 12/14/2025
1.4.0-beta.496 33 12/11/2025
1.4.0-beta.495 37 12/13/2025
1.4.0-beta.493 25 12/13/2025
1.3.1 36 12/15/2025
1.3.1-beta.491 37 12/10/2025
1.3.1-beta.490 26 12/15/2025
1.3.1-beta.486 25 12/12/2025
1.3.0 27 12/13/2025
1.3.0-beta.484 33 12/14/2025
1.3.0-beta.477 30 12/17/2025
1.3.0-beta.476 41 12/14/2025
1.3.0-beta.470 28 12/10/2025
1.3.0-beta.468 31 12/20/2025
1.3.0-beta.466 25 12/20/2025
1.2.0 26 12/19/2025
1.2.0-beta.457 30 12/11/2025
1.2.0-beta.456 27 12/17/2025
1.2.0-beta.449 24 12/11/2025
1.2.0-beta.448 30 12/13/2025
1.2.0-beta.439 26 12/13/2025
1.2.0-beta.431 26 12/12/2025
1.2.0-beta.423 30 12/14/2025
1.2.0-beta.420 35 12/20/2025
1.2.0-beta.419 28 12/10/2025
1.2.0-beta.418 23 12/11/2025
1.2.0-beta.410 26 12/20/2025
1.2.0-beta.408 29 12/09/2025
1.1.2 29 12/20/2025
1.1.2-beta.407 29 12/20/2025
1.1.2-beta.395 25 12/11/2025
1.1.1 24 12/10/2025
1.1.1-beta.392 32 12/13/2025
1.1.1-beta.390 28 12/09/2025
1.1.1-beta.389 34 12/12/2025
1.1.1-beta.388 31 12/20/2025
1.1.1-beta.387 27 12/11/2025
1.1.1-beta.386 32 12/14/2025
1.1.1-beta.385 36 12/10/2025
1.1.0 31 12/14/2025
1.1.0-beta.384 32 12/17/2025
1.1.0-alpha-379 31 12/20/2025
1.1.0-alpha-378 31 12/20/2025
1.1.0-alpha-377 30 12/20/2025
1.1.0-alpha-376 31 12/14/2025
1.1.0-alpha-375 39 12/14/2025
1.1.0-alpha-374 32 12/20/2025
1.0.7 35 12/19/2025
1.0.7-alpha-342 27 12/20/2025
1.0.6 33 12/13/2025
1.0.6-alpha-341 27 12/12/2025
1.0.6-alpha-339 33 12/11/2025
1.0.6-alpha-331 38 12/14/2025
1.0.6-alpha-330 31 12/20/2025
1.0.6-alpha-328 33 12/14/2025
1.0.6-alpha-325 32 12/14/2025
1.0.6-alpha-321 28 12/11/2025
1.0.5 37 12/13/2025
1.0.5-alpha-317 32 12/14/2025
1.0.4 30 12/13/2025
1.0.4-alpha-316 33 12/20/2025
1.0.4-alpha-314 37 12/09/2025
1.0.4-alpha-311 38 12/16/2025
1.0.4-alpha-307 33 12/18/2025
1.0.4-alpha-301 34 12/10/2025
1.0.4-alpha-300 29 12/09/2025
1.0.4-alpha-298 29 12/13/2025
1.0.4-alpha-290 32 12/20/2025
1.0.4-alpha-289 34 12/20/2025
1.0.3 37 12/20/2025
1.0.3-alpha-287 36 12/16/2025
1.0.2 30 12/13/2025
1.0.2-alpha-284 33 12/20/2025
1.0.2-alpha-283 33 12/12/2025
1.0.2-alpha-282 31 12/14/2025
1.0.2-alpha-281 28 12/13/2025
1.0.2-alpha-278 30 12/12/2025
1.0.2-alpha-277 33 12/11/2025
1.0.2-alpha-276 32 12/20/2025
1.0.2-alpha-275 25 12/20/2025
1.0.2-alpha-274 30 12/20/2025
1.0.2-alpha-273 28 12/14/2025
1.0.2-alpha-261 24 12/14/2025
1.0.2-alpha-258 29 12/20/2025
1.0.2-alpha-257 28 12/20/2025
1.0.2-alpha-255 28 12/14/2025
1.0.2-alpha-251 36 12/10/2025
1.0.2-alpha-250 34 12/16/2025
1.0.2-alpha-249 34 12/13/2025
1.0.1 32 12/13/2025
1.0.1-alpha-248 33 12/14/2025
1.0.1-alpha-243 29 12/20/2025
1.0.1-alpha-242 30 12/20/2025
1.0.1-alpha-241 26 01/06/2026
1.0.1-alpha-235 34 12/13/2025
1.0.0 25 12/13/2025
1.0.0-ci-228 30 12/20/2025
1.0.0-alpha-231 37 12/14/2025
1.0.0-alpha-229 33 12/14/2025
0.17.1 24 12/20/2025
0.17.1-alpha-179 27 12/20/2025
0.17.1-alpha-178 27 12/20/2025
0.17.0 27 12/14/2025
0.17.0-alpha-177 28 01/01/2026
0.17.0-alpha-174 29 12/15/2025
0.17.0-alpha-173 28 12/11/2025
0.17.0-alpha-172 30 12/20/2025
0.17.0-alpha-171 33 12/14/2025
0.17.0-alpha-170 22 12/13/2025
0.17.0-alpha-169 24 12/12/2025
0.16.1 34 12/13/2025
0.16.1-alpha-99 31 12/14/2025
0.16.1-alpha-96 29 12/13/2025
0.16.1-alpha-91 28 12/20/2025
0.16.1-alpha-168 27 12/14/2025
0.16.1-alpha-167 25 12/14/2025
0.16.1-alpha-155 26 12/20/2025
0.16.1-alpha-153 33 12/20/2025
0.16.1-alpha-152 28 12/20/2025
0.16.1-alpha-148 23 12/20/2025
0.16.1-alpha-145 28 12/14/2025
0.16.1-alpha-144 20 12/13/2025
0.16.1-alpha-133 32 12/14/2025
0.16.1-alpha-127 27 12/20/2025
0.16.1-alpha-125 26 12/14/2025
0.16.1-alpha-120 29 12/20/2025
0.16.1-alpha-114 25 12/13/2025
0.16.1-alpha-112 30 12/14/2025
0.16.1-alpha-110 32 12/13/2025
0.16.1-alpha-108 23 12/14/2025
0.16.1-alpha-106 31 12/09/2025
0.16.1-alpha-104 25 12/19/2025
0.16.0 27 12/20/2025
0.16.0-alpha-86 29 12/14/2025
0.16.0-alpha-85 25 12/20/2025
0.16.0-alpha-84 28 12/10/2025
0.16.0-alpha-80 26 12/20/2025
0.16.0-alpha-79 32 12/14/2025
0.16.0-alpha-78 25 12/10/2025
0.16.0-alpha-77 32 12/13/2025
0.16.0-alpha-76 26 12/16/2025
0.16.0-alpha-75 24 12/20/2025
0.16.0-alpha-72 21 12/20/2025
0.15.0 22 12/20/2025
0.15.0-alpha-14 25 12/20/2025
0.14.0 27 12/13/2025
0.14.0-alpha-818 33 12/14/2025
0.14.0-alpha-817 27 12/10/2025
0.14.0-alpha-813 25 12/20/2025
0.14.0-alpha-811 30 12/14/2025
0.14.0-alpha-809 28 12/19/2025
0.14.0-alpha-805 23 12/20/2025
0.14.0-alpha-803 29 12/20/2025
0.14.0-alpha-802 34 12/20/2025
0.14.0-alpha-801 24 12/10/2025
0.14.0-alpha-798 38 12/20/2025
0.14.0-alpha-796 33 12/11/2025
0.14.0-alpha-794 30 12/14/2025
0.14.0-alpha-793 24 12/10/2025
0.14.0-alpha-790 30 12/14/2025
0.14.0-alpha-789 27 12/20/2025
0.14.0-alpha-788 36 12/17/2025
0.14.0-alpha-787 26 12/20/2025
0.14.0-alpha-784 23 12/20/2025
0.14.0-alpha-783 27 12/20/2025
0.13.0 31 12/13/2025
0.13.0-alpha-782 29 12/14/2025
0.13.0-alpha-775 32 12/20/2025
0.13.0-alpha-771 32 12/20/2025
0.13.0-alpha-768 30 12/10/2025
0.13.0-alpha-766 29 12/20/2025
0.13.0-alpha-764 34 12/20/2025
0.13.0-alpha-763 28 12/20/2025
0.13.0-alpha-760 23 12/20/2025
0.13.0-alpha-758 27 12/20/2025
0.13.0-alpha-756 25 12/20/2025
0.13.0-alpha-754 30 12/20/2025
0.13.0-alpha-748 28 12/14/2025
0.13.0-alpha-745 30 01/06/2026
0.13.0-alpha-744 24 12/14/2025
0.13.0-alpha-743 31 12/11/2025
0.13.0-alpha-742 27 12/21/2025
0.13.0-alpha-739 34 12/20/2025
0.13.0-alpha-737 25 12/17/2025
0.13.0-alpha-735 23 12/20/2025
0.13.0-alpha-734 28 12/20/2025
0.13.0-alpha-733 30 12/20/2025
0.12.1 28 12/20/2025
0.12.0 30 12/20/2025
0.11.0 31 12/20/2025
0.10.1 24 12/20/2025
0.10.0 42 12/10/2025
0.9.11 28 12/22/2025
0.9.10 26 12/20/2025
0.9.9.2 30 12/24/2025
0.9.9.1 29 12/13/2025
0.9.9 29 12/20/2025
0.9.8.1 30 12/20/2025
0.9.8 26 12/20/2025
0.9.7 24 12/10/2025
0.9.6 26 12/20/2025
0.9.5 22 12/20/2025
0.9.4 27 12/20/2025
0.9.3 25 12/14/2025
0.9.2 31 12/11/2025
0.9.1 24 12/20/2025
0.9.0 29 12/14/2025
0.8.9 31 12/20/2025
0.8.8 29 12/16/2025
0.8.7.1 28 12/14/2025
0.8.7 27 12/14/2025
0.8.6 23 12/20/2025
0.8.5 28 12/20/2025
0.8.4.1 28 12/14/2025
0.8.4 33 12/12/2025
0.8.3 0 04/21/2015
0.8.2 0 04/15/2015
0.8.1 25 12/20/2025
0.8.0 27 12/13/2025
0.7.0 26 12/14/2025
0.6.1 30 12/12/2025
0.6.0 26 12/16/2025
0.5.1 30 12/13/2025
0.5.0 31 12/20/2025
0.4.0 27 12/20/2025
0.3.7 24 12/20/2025
0.3.6 28 12/10/2025
0.3.5 27 12/20/2025
0.3.4 26 12/20/2025
0.3.3 23 12/10/2025
0.3.2 32 12/14/2025
0.3.1 27 12/22/2025
0.3.0 27 12/13/2025
0.2.9 28 12/10/2025
0.2.8 28 12/13/2025
0.2.7 22 12/20/2025
0.2.6 24 12/20/2025
0.2.5 23 12/20/2025
0.2.4 23 12/20/2025
0.2.3 25 12/20/2025
0.2.2 23 12/20/2025
0.2.1 26 12/14/2025
0.2.0 26 12/13/2025