-
Notifications
You must be signed in to change notification settings - Fork 13.1k
Description
π Search Terms
"jsx react", "jsx scope", "jsx generic"
β Viability Checklist
- This wouldn't be a breaking change in existing TypeScript/JavaScript code
- This wouldn't change the runtime behavior of existing JavaScript code
- This could be implemented without emitting different JS based on the types of the expressions
- This isn't a runtime feature (e.g. library functionality, non-ECMAScript syntax with JavaScript output, new syntax sugar for JS, etc.)
- This isn't a request to add a new utility type: https://github.com/microsoft/TypeScript/wiki/No-New-Utility-Types
- This feature would agree with the rest of our Design Goals: https://github.com/Microsoft/TypeScript/wiki/TypeScript-Design-Goals
β Suggestion
Right now TypeScript's JSX/TSX options are tied to React:
- This includes
jsxtsconfig option names (react,react-jsx,react-nativeand etc.) - And TypeScript docs (official docs describe JSX/TSX usage only giving examples for React).
All this creates great confusion and makes new people think that JSX/TSX stuff is ONLY used for React which damages the whole idea of jsx. Yes, it used to be like that from historical point of view, but I think it is time to separate one from another.
The problem is that current option names (and tsconfig docs) are not self-explanatory for someone who never worked with React or front end in general.
I think that jsx has grown enought to have it's own independent standart.
Something like this:
"jsx": {
"mode": "scope" | "import" | "preserve",
"elementTypeStrictness": "strict" | "relaxed",
"elementSpec": "two-argument" | "three-argument",
"elementFactory": "jsx",
"fragmentFactory": "Fragment",
"importSource": "...",
}From that perspective, React will be just one example of how this general feature can be used, not the only one!
Of course it also worth mentioning that there is a awaited by many feature request to provide full generic support for jsx nodes instead of widening to JSX.Element:
- Type JSX elements based on createElement functionΒ #14729
- Decouple jsx element type from jsx factory return type and sfc return typeΒ #21699
π Motivating Example
Separating JSX/TSX from React especially on docs level would attract more people to writing their own XML-in-JS languages, instead of using external tools.
π» Use Cases
This is mainly useful for writing content with strict typings and full JS/TS environment support (variables, conditions, functions, comments and etc) β no need to use external Markdown/XML/... parsers.
Consider the following prose example:
export const pythagoreanTheorem = (
<Term
title="Pythagorean Theorem"
direction="row"
$snippet={{
search: { synonyms: ['Pythagoras', 'Right Triangle Theorem'] },
description:
'Fundamental theorem relating sides of a right triangle',
}}
>
<TermMain>
<p>
In any right triangle, the square of the length of the
hypotenuse <M>c</M> is equal to the sum of the squares of
the lengths of the other two sides <M>a</M> and <M>b</M>.
</p>
<BlockMath>{`
a^2 + b^2 = c^2
`}</BlockMath>
</TermMain>
<TermSection title="Geometric Interpretation">
<p>
The theorem can be visualized as the area of the square
constructed on the hypotenuse being equal to the sum of the
areas of the squares constructed on the other two sides.
This relationship holds true for all right triangles,
regardless of their size or orientation.
</p>
</TermSection>
<TermSection title="Common Examples">
<p>
The most well-known Pythagorean triple is <M>(3, 4, 5)</M>,
where <M>3^2 + 4^2 = 9 + 16 = 25 = 5^2</M>. Other common
triples include <M>(5, 12, 13)</M> and <M>(8, 15, 17)</M>.
</p>
</TermSection>
</Term>
);This is not a React code. All these tags are custom functions so we can parse it, detect writing errors on both compile and runtime levels, extract search snippets and do so much stuff! And all this within TypeScript β no external tools needed.
Of course XML-in-JS can be used not only for prose content, but for other structured data, that is easier to express with XML structures other than JS code.
Not to mention how flexible it is β we can save such XML structures to variables, export and import them in different files!