This package is a patch for react-dom
18.3.1.
This packages is a backport of facebook/react#26228, which fixes a bug that HTML generated by SSG or SSG can contain NUL especially in CJK languages, for React 18.x.
See the following issue in React and its frameworks for details:
- facebook/react#24985
- facebook/react#31134
- facebook/docusaurus#9985
- meilisearch/docs-scraper#474
- remix-run/remix#8203
Update react-dom
to 18.3.1 before the following steps.
After patch-package
(and additional postinstall-postinstall
only for Yarn) is installed and "postinstall": "patch-package"
is added to your package.json
, run the following command.
curl -LfO --output-dir node_modules/react-dom/cjs https://github.com/tats-u/react-dom-no-nul/raw/850327cbc752bf95e94114699861d142741f4181/cjs/react-dom-server.node.development.js
curl -LfO --output-dir node_modules/react-dom/cjs https://github.com/tats-u/react-dom-no-nul/raw/850327cbc752bf95e94114699861d142741f4181/cjs/react-dom-server.node.production.min.js
npx patch-package react-dom
Commit the generated patches/react-dom+18.3.1.patch
file to your repository.
Use the builtin pnpm patch
command.
pnpm patch react-dom@18.3.1
# Copy the path of the generated temporary directory
# Assuming it is /path/to/temp
WORKSPACE_DIR=/path/to/temp
# PowerShell: $WORKSPACE_DIR = "/path/to/temp"
curl -LfO --output-dir "$WORKSPACE_DIR/cjs" https://github.com/tats-u/react-dom-no-nul/raw/850327cbc752bf95e94114699861d142741f4181/cjs/react-dom-server.node.development.js
curl -LfO --output-dir "$WORKSPACE_DIR/cjs" https://github.com/tats-u/react-dom-no-nul/raw/850327cbc752bf95e94114699861d142741f4181/cjs/react-dom-server.node.production.min.js
pnpm patch-commit "$WORKSPACE_DIR"
The following part will be added to package.json
by pnpm patch-commit
:
"@your/last-dependency": "version"
- }
+ },
+ "pnpm": {
+ "patchedDependencies": {
+ "react-dom@18.3.1": "patches/react-dom@18.3.1.patch"
+ }
+ }
}
Commit the generated patches/react-dom@18.3.1.patch
file and the modified package.json
to your repository.
The generated patches/react-dom@18.3.1.patch
will be the same as that in this repository. You can copy it to your repository and apply the above change to package.json
instead of running pnpm patch
.
It supports the builtin yarn patch
command like pnpm.
See the Yarn documentation for details.
850327cbc752bf95e94114699861d142741f4181
is the commit ID of the latest commit of branch package-18.3.1
and the tag patched-package-18.3.1
. In case this repository were tampered by a cracker who had hijacked my account, please use the commit ID instead of the branch or the tag name.
{
"name": "your-react-app",
"dependencies": {
"some-react-framework": "^1.2.3",
"other-dependencies": "^4.5.6",
"react-dom": "github:tats-u/react-dom-no-nul#850327cbc752bf95e94114699861d142741f4181"
}
}
Then, run npm i
or yarn
to install the package.
You can use this package until you upgrade React to 19.x if you're using React 18.x. That patch has been applied to React 19.x or newer. If you are going to upgrade React to 19.x or newer, you should replace this package with an official newer version by rewriting dependencies
in package.json
, or removing the patch created by patch-package
, Yarn, or pnpm.
You do not need to use this package at all if you're using Next.js (Pages Router in 14.x or App Router) because it uses newer unstable versions of React.
You do not need to use this package at all if you don't use either of Node.js or npm packages. This bug can appear only when you use frameworks depending on the Node.js stream (and its polyfills in other JavaScript engines).
sed -i -e '11s/\(d<b.length&&(t(a,k\))/\1.subarray(0,l))/' node_modules/react-dom/cjs/react-dom-server.node.production.min.js
sed -i -e '129s/currentView/currentView.subarray(0, writtenBytes)/' node_modules/react-dom/cjs/react-dom-server.node.development.js
https://unpkg.com/browse/react-dom@18.3.1/cjs/react-dom-server.node.production.min.js Line 11, Character 243
Replace t(a,k)
with t(a,k).subarray(0,l)
https://unpkg.com/browse/react-dom@18.3.1/cjs/react-dom-server.node.development.js Line 129
Replace currentView
with currentView.subarray(0, writtenBytes)
The other files are unchanged and equivalent to the original React 18.3.1 files.
https://github.com/tats-u/react-dom-no-nul/commit/850327cbc752bf95e94114699861d142741f4181
Diff in the original PR (facebook/react#26228) (Note: (expression: any)
is the any
casting expression in Flow, which is equivalent to expression as any
in TypeScript)