cheerio@1.0.0-rc.11 is hopefully the last RC before the 1.0.0 release of Cheerio. There are two APIs that will be added for the next major release: An exract method (cheeriojs/cheerio#2523) and NodeJS specific loader methods (cheeriojs/cheerio#2051). These are still in flux and I'd appreciate feedback on the proposals.
A big thank you to everyone that contributed to this release! This includes code contributors, as well as the amazing financial support on GitHub Sponsors!
Under the hood, a lot of work for this release went into updating parse5, cheerio's default HTML parser. Have a look at parse5's release notes to see what has changed there.
Breaking
Cheerio is now a dual CommonJS and ESM module. That means that deep imports will now fail in newer versions of Node. cheeriojs/cheerio#2508
Starting with 1.0.0-rc.4, release notes are exclusively tracked in
GitHub Releases.
1.0.0-rc.3 / 2019-04-06
This release corrects a test expectation that was fixed by one of the project's
dependencies.
1.0.0-rc.2 / 2017-07-02
This release changes Cheerio's default parser to the Parse5 HTML
parser. Parse5 is an excellent project
that rigorously conforms to the HTML standard. It does not support XML, so
Cheerio continues to use htmlparser2
when working with XML documents.
This switch addresses many long-standing bugs in Cheerio, but some users may
experience slower behavior in performance-critical applications. In addition,
htmlparser2 is more forgiving of invalid markup which can be useful when
input sourced from a third party and cannot be corrected. For these reasons,
the load method also accepts a DOM structure as produced by the htmlparser2
library. See the project's "readme" file for more details on this usage
pattern.
Migrating from version 0.x
cheerio.load( html[, options ] ) This method continues to act as a "factory"
function. It produces functions that define an API that is similar to the
global jQuery function provided by the jQuery library. The generated function
operates on a DOM structure based on the provided HTML.
In releases prior to version 1.0, the provided HTML was interpreted as a
document fragment. Following version 1.0, strings provided to the load method
are interpreted as documents. The same example will produce a $ function that
operates on a full HTML document, including an <html> document element with
nested <head> and <body> tags. This mimics web browser behavior much more
closely, but may require alterations to existing code.
For example, the following code will produce different results between 0.x and
1.0 releases:
var $ = cheerio.load('<p>Hello, <b>world</b>!</p>');
$.root().html();
//=> In version 0.x: '<p>Hello, <b>world</b>!</p>'
//=> In version 1.0: '<html><head></head><body><p>Hello, <b>world</b>!</p></body></html>'
Users wishing to parse, manipulate, and render full documents should not need
to modify their code. Likewise, code that does not interact with the "root"
cheerio@1.0.0-rc.11 is hopefully the last RC before the 1.0.0 release of Cheerio. There are two APIs that will be added for the next major release: An exract method (cheeriojs/cheerio#2523) and NodeJS specific loader methods (cheeriojs/cheerio#2051). These are still in flux and I'd appreciate feedback on the proposals.
A big thank you to everyone that contributed to this release! This includes code contributors, as well as the amazing financial support on GitHub Sponsors!
Under the hood, a lot of work for this release went into updating parse5, cheerio's default HTML parser. Have a look at parse5's release notes to see what has changed there.
Breaking
Cheerio is now a dual CommonJS and ESM module. That means that deep imports will now fail in newer versions of Node. cheeriojs/cheerio#2508
Starting with 1.0.0-rc.4, release notes are exclusively tracked in
GitHub Releases.
1.0.0-rc.3 / 2019-04-06
This release corrects a test expectation that was fixed by one of the project's
dependencies.
1.0.0-rc.2 / 2017-07-02
This release changes Cheerio's default parser to the Parse5 HTML
parser. Parse5 is an excellent project
that rigorously conforms to the HTML standard. It does not support XML, so
Cheerio continues to use htmlparser2
when working with XML documents.
This switch addresses many long-standing bugs in Cheerio, but some users may
experience slower behavior in performance-critical applications. In addition,
htmlparser2 is more forgiving of invalid markup which can be useful when
input sourced from a third party and cannot be corrected. For these reasons,
the load method also accepts a DOM structure as produced by the htmlparser2
library. See the project's "readme" file for more details on this usage
pattern.
Migrating from version 0.x
cheerio.load( html[, options ] ) This method continues to act as a "factory"
function. It produces functions that define an API that is similar to the
global jQuery function provided by the jQuery library. The generated function
operates on a DOM structure based on the provided HTML.
In releases prior to version 1.0, the provided HTML was interpreted as a
document fragment. Following version 1.0, strings provided to the load method
are interpreted as documents. The same example will produce a $ function that
operates on a full HTML document, including an <html> document element with
nested <head> and <body> tags. This mimics web browser behavior much more
closely, but may require alterations to existing code.
For example, the following code will produce different results between 0.x and
1.0 releases:
var $ = cheerio.load('<p>Hello, <b>world</b>!</p>');
$.root().html();
//=> In version 0.x: '<p>Hello, <b>world</b>!</p>'
//=> In version 1.0: '<html><head></head><body><p>Hello, <b>world</b>!</p></body></html>'
Users wishing to parse, manipulate, and render full documents should not need
to modify their code. Likewise, code that does not interact with the "root"
Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting @dependabot rebase.
Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR:
- `@dependabot rebase` will rebase this PR
- `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it
- `@dependabot merge` will merge this PR after your CI passes on it
- `@dependabot squash and merge` will squash and merge this PR after your CI passes on it
- `@dependabot cancel merge` will cancel a previously requested merge and block automerging
- `@dependabot reopen` will reopen this PR if it is closed
- `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually
- `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself)
- `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself)
- `@dependabot use these labels` will set the current labels as the default for future PRs for this repo and language
- `@dependabot use these reviewers` will set the current reviewers as the default for future PRs for this repo and language
- `@dependabot use these assignees` will set the current assignees as the default for future PRs for this repo and language
- `@dependabot use this milestone` will set the current milestone as the default for future PRs for this repo and language
You can disable automated security fix PRs for this repo from the [Security Alerts page](https://github.com/qiubohong/qiubohong.github.io/network/alerts).
Bumps nth-check, cheerio and cheerio. These dependencies needed to be updated together. Updates
nth-check
from 1.0.2 to 2.1.1Release notes
Sourced from nth-check's releases.
Commits
639fd2a
2.1.10eec65b
fix(test): AddmoduleNameMapper
aeeb067
fix: Fix ESM432ebc6
2.1.03e8cd1e
feat: Addgenerate
andsequence
methods (#207)57a5c62
feat: Add ESM (#206)1ce0c7c
chore(deps-dev): Bump@types/node
from 17.0.34 to 17.0.35 (#205)eebb040
chore(deps-dev): Bump@typescript-eslint/parser
from 5.24.0 to 5.25.0 (#204)a316aaa
chore(deps-dev): Bump@typescript-eslint/eslint-plugin
(#203)454c0de
chore(deps-dev): Bump@typescript-eslint/eslint-plugin
(#202)Updates
cheerio
from 0.22.0 to 1.0.0-rc.12Release notes
Sourced from cheerio's releases.
... (truncated)
Changelog
Sourced from cheerio's changelog.
... (truncated)
Commits
d1cbc66
1.0.0-rc.124b4432f
chore: Update license to 202272e3c42
chore(deps): Remove tslib dependency810ce07
build(deps-dev): bump@types/node
from 17.0.43 to 18.0.0 (#2596)b6bdc24
doc(comments): fix minor spelling mistake (#2585)aef3205
Update Sponsors (#2599)febcb41
build(deps-dev): bump jsdom from 19.0.0 to 20.0.0 (#2606)16a3adb
docs: update History.md (#2588)43d9f50
fix(package): Allow imports ofcheerio/lib/utils
(#2601)6fe629a
build(deps-dev): bump@types/jest
from 28.1.2 to 28.1.3 (#2609)Updates
cheerio
from 1.0.0-rc.3 to 1.0.0-rc.12Release notes
Sourced from cheerio's releases.
... (truncated)
Changelog
Sourced from cheerio's changelog.
... (truncated)
Commits
d1cbc66
1.0.0-rc.124b4432f
chore: Update license to 202272e3c42
chore(deps): Remove tslib dependency810ce07
build(deps-dev): bump@types/node
from 17.0.43 to 18.0.0 (#2596)b6bdc24
doc(comments): fix minor spelling mistake (#2585)aef3205
Update Sponsors (#2599)febcb41
build(deps-dev): bump jsdom from 19.0.0 to 20.0.0 (#2606)16a3adb
docs: update History.md (#2588)43d9f50
fix(package): Allow imports ofcheerio/lib/utils
(#2601)6fe629a
build(deps-dev): bump@types/jest
from 28.1.2 to 28.1.3 (#2609)Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting
@dependabot rebase
.Dependabot commands and options
You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) - `@dependabot use these labels` will set the current labels as the default for future PRs for this repo and language - `@dependabot use these reviewers` will set the current reviewers as the default for future PRs for this repo and language - `@dependabot use these assignees` will set the current assignees as the default for future PRs for this repo and language - `@dependabot use this milestone` will set the current milestone as the default for future PRs for this repo and language You can disable automated security fix PRs for this repo from the [Security Alerts page](https://github.com/qiubohong/qiubohong.github.io/network/alerts).