XHTM is alternative implementation of HTM without HTM-specific limitations. Low-level machinery is rejected in favor of readability and better HTML support.
- Self-closing tags support htm`<input><br>`→[h('input'), h('br')].
- HTML directives <!doctype>,<?xml?>etc. support #91.
- Optionally closed tags support <p>foo<p>bar→<p>foo</p><p>bar</p>#91.
- Interpolated props are exposed as arrays html`<a class="a ${b} c"/>`→h('a', { class: ['a ', b, ' c'] }).
- Calculated tag names #109 support.
- Ignoring null-like arguments (customizable) #129.
- Spaces formatting closer to HTML; elements with preserved formatting (#23).
- No integrations exported, no babel compilers.
- No cache.
xhtm is by default fully compatible with htm and can be used as drop-in replacement.
import htm from 'xhtm'
import { render, h } from 'preact'
html = htm.bind(h)
render(html`
  <h1>Hello World!</h1>
  <p>Some paragraph<br>
  <p>Another paragraph
`, document.getElementById('app'))For htm manual, refer to htm docs.
Generally HTM is a better choice, since it has better performance and enables caching.
But if your app doesn't render components frequently or you need HTML support, then XHTM can be a good choice.
Originally that was just minimal HTML parser implementation (~60LOC), best from 10 variants in R&D branches.
🕉️
