From ed720ef98bffde2c84fb2a33ea7db3241825f3e2 Mon Sep 17 00:00:00 2001 From: Jovi De Croock Date: Thu, 12 Dec 2024 09:24:18 +0100 Subject: [PATCH] improve perf with array pre-allocate (#403) --- .changeset/giant-schools-explode.md | 5 +++++ package-lock.json | 9 ++++----- src/index.js | 5 +++-- 3 files changed, 12 insertions(+), 7 deletions(-) create mode 100644 .changeset/giant-schools-explode.md diff --git a/.changeset/giant-schools-explode.md b/.changeset/giant-schools-explode.md new file mode 100644 index 0000000..5495594 --- /dev/null +++ b/.changeset/giant-schools-explode.md @@ -0,0 +1,5 @@ +--- +'preact-render-to-string': patch +--- + +Improve performance by pre-allocating arrays diff --git a/package-lock.json b/package-lock.json index 8ac19e7..e4d3c80 100644 --- a/package-lock.json +++ b/package-lock.json @@ -14,7 +14,7 @@ "@babel/register": "^7.12.10", "@changesets/changelog-github": "^0.4.1", "@changesets/cli": "^2.18.0", - "baseline-rts": "npm:preact-render-to-string@latest", + "baseline-rts": "npm:preact-render-to-string@6.5.11", "benchmarkjs-pretty": "^2.0.1", "chai": "^4.2.0", "check-export-map": "^1.3.1", @@ -2561,11 +2561,10 @@ }, "node_modules/baseline-rts": { "name": "preact-render-to-string", - "version": "6.5.10", - "resolved": "https://registry.npmjs.org/preact-render-to-string/-/preact-render-to-string-6.5.10.tgz", - "integrity": "sha512-BJdypTQaBA5UbTF9NKZS3zP93Sw33tZOxNXIfuHofqOZFoMdsquNkVebs/HkEw0in/Qbi6Ep/Anngnj+VsHeBQ==", + "version": "6.5.11", + "resolved": "https://registry.npmjs.org/preact-render-to-string/-/preact-render-to-string-6.5.11.tgz", + "integrity": "sha512-ubnauqoGczeGISiOh6RjX0/cdaF8v/oDXIjO85XALCQjwQP+SB4RDXXtvZ6yTYSjG+PC1QRP2AhPgCEsM2EvUw==", "dev": true, - "license": "MIT", "peerDependencies": { "preact": ">=10" } diff --git a/src/index.js b/src/index.js index c648b4f..a617432 100644 --- a/src/index.js +++ b/src/index.js @@ -244,7 +244,8 @@ function _renderToString( let rendered = EMPTY_STR, renderArray; parent[CHILDREN] = vnode; - for (let i = 0; i < vnode.length; i++) { + const vnodeLength = vnode.length; + for (let i = 0; i < vnodeLength; i++) { let child = vnode[i]; if (child == null || typeof child == 'boolean') continue; @@ -262,7 +263,7 @@ function _renderToString( rendered = rendered + childRender; } else { if (!renderArray) { - renderArray = []; + renderArray = new Array(vnodeLength); } if (rendered) renderArray.push(rendered);