TSX support to generate vanilla document.createElement code.
TSX, or Typescript JSX, is the Typescript flavor of JSX which was made popular by the React framework. It allows developers to write XML/HTML code along with Typescript code, making DOM generation much easier.
Typescript has built-in React JSX support, but it can also utilize a customized JSX factory method to generate code for non-React context. vanilla-tsx is such a JSX factory which utilizes the vanilla document.createElement
function to generate DOM.
-
Get vanilla-tsx on npm.
-
In your Typescript project, open your tsconfig.json file, add the following code:
{ "compilerOptions": { /* ... */ "jsx": "react", /* <-- add this line */ } /* ... */ }
-
Open or create a .tsx file, add the following code to the beginning:
/** @jsx JsxFactory */ import { JsxFactory } from "vanilla-tsx";
-
Now you can write TSX code, and all DOM elements will be generated with
document.createElement
(anddocument.createElementNS
for SVG elements).
- Generate DOM elements with
document.createElement
- Generate SVG elements with
document.createElementNS
- Generate event handling code for attributes whose name matches
onEventName
- Support custom function tag
- Correctly generate valueless attributes (e.g.
<input disable />
) - Fix attribute generation for
vector-effect