mirror of
https://github.com/honojs/hono.git
synced 2024-12-01 11:51:01 +01:00
85cbf3e984
* perf(jsx): Update benchmark for JSX. * perf(utils/html): Improve `escape` performance. Improved `escape` performance with reference to the react-dom implementation. * refactor(utils/html): Subdivide HtmlEscapedString * perf(jsx): Rewrite JSX with new `escapeToBuffer` and `JSXNode`. * refactor(jsx): A function `jsx` returns `JSXNode` now. * perf(html): Rewrite html middleware with new `escapeToBuffer`. * Update tests for JSX. * Update tests for utils/html.
73 lines
2.1 KiB
TypeScript
73 lines
2.1 KiB
TypeScript
import Benchmark from 'benchmark'
|
|
|
|
import Nano, { Fragment as NanoFragment } from 'nano-jsx'
|
|
import * as Preact from 'preact'
|
|
import { render as renderByPreact } from 'preact-render-to-string'
|
|
import React from 'react'
|
|
import { renderToString as renderByReact } from 'react-dom/server'
|
|
|
|
import * as HonoJSX from '../../src/middleware/jsx'
|
|
|
|
const buildPage = ({ jsx, Fragment }: { jsx: any; Fragment: any }) => {
|
|
const Content = () => (
|
|
<>
|
|
<p id='a' class='class-name'>
|
|
1<br />a
|
|
</p>
|
|
<p id='b' class='class-name'>
|
|
2<br />b
|
|
</p>
|
|
<div dangerouslySetInnerHTML={{ __html: '<p id="c" class="class-name">3<br/>c</p>' }} />
|
|
{null}
|
|
{undefined}
|
|
</>
|
|
)
|
|
|
|
const Form = () => (
|
|
<form>
|
|
<input type='text' value='1234567890 < 1234567891' readonly tabindex={1} />
|
|
<input type='checkbox' value='1234567890 < 1234567891' checked={true} tabindex={2} />
|
|
<input type='checkbox' value='1234567890 < 1234567891' checked={true} tabindex={3} />
|
|
<input type='checkbox' value='1234567890 < 1234567891' checked={false} tabindex={4} />
|
|
<input type='checkbox' value='1234567890 < 1234567891' checked={false} tabindex={5} />
|
|
</form>
|
|
)
|
|
|
|
return () => (
|
|
<html>
|
|
<body>
|
|
<Content />
|
|
<Form />
|
|
</body>
|
|
</html>
|
|
)
|
|
}
|
|
|
|
const PageByHonoJSX = buildPage(HonoJSX)
|
|
const PageByReact = buildPage({ jsx: React.createElement, Fragment: React.Fragment })
|
|
const PageByNano = buildPage({ jsx: Nano.h, Fragment: NanoFragment })
|
|
const PageByPreact = buildPage({ jsx: Preact.h, Fragment: Preact.Fragment })
|
|
|
|
const suite = new Benchmark.Suite()
|
|
|
|
suite
|
|
.add('Hono', () => {
|
|
PageByHonoJSX().toString()
|
|
})
|
|
.add('React', () => {
|
|
renderByReact(PageByReact())
|
|
})
|
|
.add('Preact', () => {
|
|
renderByPreact(PageByPreact())
|
|
})
|
|
.add('Nano', () => {
|
|
Nano.renderSSR(PageByNano)
|
|
})
|
|
.on('cycle', (ev: any) => {
|
|
console.log(String(ev.target))
|
|
})
|
|
.on('complete', (ev: any) => {
|
|
console.log(`Fastest is ${ev.currentTarget.filter('fastest').map('name')}`)
|
|
})
|
|
.run({ async: true })
|