詳解TypeScript編譯TSX文件的方法
一、簡介
因為使用 Cycle.js 的 Vite + TSX 所以想詳細(xì)的探索 TSX 在 TS 配置中的編譯情況,本文主要講解 tsconfig 和 tsx 編譯與配置。以常見的框架 PReact 的虛擬 DOM + TSX 組合、snabbdom + TSX 組合不同的配置以及編譯輸出。
除了 TS 還可以渲染, babel 等編譯器進(jìn)行編譯。
二、配置項目
| 配置選項 | 描述 | 示例配置 |
|---|---|---|
"jsx" | 指定 JSX 的處理方式 | "jsx": "react" |
"jsxFactory" | 指定在 JSX 中使用的工廠函數(shù) | "jsxFactory": "h" |
"jsxFragmentFactory" | 指定在 JSX 中使用的碎片工廠函數(shù) | "jsxFragmentFactory": "Fragment" |
"jsxImportSource" | 指定從哪個模塊導(dǎo)入 JSX 相關(guān)的符號 | "jsxImportSource": "react" |
"reactNamespace" | 指定全局變量或模塊的命名空間,用于 React | "reactNamespace": "myReact" |
"jsxMode" | 指定 JSX 模式,僅在 TypeScript 4.1+ 中可用 | "jsxMode": "react" |
例如: Preact 提供了自己的渲染函數(shù) h, 用來渲染組件,此時就對應(yīng)著
jsxFactory配置項。
三、配置文件和命令行的優(yōu)先級問題
- 命令行參數(shù)優(yōu)先級高
- 配置文件優(yōu)先級低
例如: jsx 標(biāo)識符在命令行中使用 --jsx react 會覆蓋 jsx: react-jsx。
四、JSX 標(biāo)識
1) 沒有標(biāo)識符
沒有標(biāo)識符時候,不支持編譯 TSX/JSX 文件。
2)preserve 標(biāo)識符
默認(rèn)會將 TSX 文件裝換成 JSX 文件, 其他的 JSX 結(jié)構(gòu)沒有改變
3)react/react-native 標(biāo)識符
默認(rèn)會使用 React.createElement 來創(chuàng)建元素,輸出 js 文件,可以與 jsxFactory 工廠函數(shù)替換庫中的函數(shù)
4)react-jsx/react-jsxdev
會使用相關(guān) React 的 jsx-runtime 進(jìn)行編譯,也可以使用自定義 jsx-runtime 運行時。
五、PReact 虛擬dom 和 JSX
1) 寫法一: 使用 preact 運行時
{
"jsx": "react-jsx",
"jsxImportSource": "preact",
}得到的編譯結(jié)果是:
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const jsx_runtime_1 = require("preact/jsx-runtime");
function Card({ title, children }) {
return ((0, jsx_runtime_1.jsxs)("div", { class: "card", children: [(0, jsx_runtime_1.jsx)("h1", { children: title }), children] }));
}使用 preact 的 jsx 運行時。
2) 寫法二: 使用 preact 提供的渲染函數(shù) h 進(jìn)行渲染
{
"jsx": "react",
"jsxFactory": "h",
}得到的編譯結(jié)果是:
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const preact_1 = require("preact");
function Card({ title, children }) {
return ((0, preact_1.h)("div", { class: "card" },
(0, preact_1.h)("h1", null, title),
children));
}
;使用 preact 的渲染函數(shù) h。
六、snabbdom 與 @herp-inc/snabbdom-jsx
1)寫法一:使用 jsx
{
"jsx": "react-jsx",
"jsxImportSource": "@herp-inc/snabbdom-jsx",
}編譯結(jié)果
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const jsx_runtime_1 = require("@herp-inc/snabbdom-jsx/jsx-runtime");
// import { jsx } from '@herp-inc/snabbdom-jsx'
const EventComp = () => {
return (0, jsx_runtime_1.jsx)("div", { children: "sdfdsfdd" });
};
exports.default = EventComp;使用 jsx 的運行時
2) 寫法: jsx 使用
{
"jsx": "react",
"jsxFactory": "jsx",
"jsxFragmentFactory": "Fragment",
}編譯的結(jié)果:
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
const snabbdom_jsx_1 = require("@herp-inc/snabbdom-jsx");
const EventComp = () => {
return (0, snabbdom_jsx_1.jsx)("div", null, "sdfdsfdd");
};
exports.default = EventComp;使用@herp-inc/snabbdom-jsx內(nèi)部實現(xiàn)的 jsx 函數(shù)。
七、snabbdom-jsx
沒有運行時:snabbdom-jsx/jsx-runtime 所以不能使用 jsx 運行時編譯
1)寫法一
{
"jsx": "react",
"jsxFactory": "html",
}組件寫法以及編譯后的寫法
import { html } from 'snabbdom-jsx';
export const vnode = <div>Hello JSX</div>
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.vnode = void 0;
const snabbdom_jsx_1 = require("snabbdom-jsx");
exports.vnode = (0, snabbdom_jsx_1.html)("div", null, "Hello JSX");是使用了 snabbdom-jsx 提供的 html函數(shù),源碼如下:
module.exports = {
html: JSX(undefined),
svg: JSX(SVGNS, 'attrs'),
JSX: JSX
};小結(jié)
本文的主要目的是講解 TS 中編譯配置和在不同的環(huán)境下編譯不同的 JSX/TSX 文件,由于 React 的JSX 實現(xiàn)了 jsx-runtime,所以基本上都有兩套編譯路徑。若不了解 TSX 編譯,本文可以很好的說明。其次可以使用 babel 等其他的工具進(jìn)行編譯學(xué)習(xí)。Cycle.js 中使用 snabbdom 作為虛擬 dom, 可以使用 TSX 不優(yōu)雅的虛擬 dom 的寫法。
以上就是詳解TypeScript編譯TSX文件的方法的詳細(xì)內(nèi)容,更多關(guān)于TypeScript編譯TSX文件的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序?qū)崿F(xiàn)的一鍵連接wifi功能示例
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的一鍵連接wifi功能,結(jié)合實例形式分析了微信小程序操作WiFi連接的模塊初始化、配置、連接等相關(guān)操作技巧,需要的朋友可以參考下2019-04-04
Javascript將數(shù)字轉(zhuǎn)化成為貨幣格式字符串
這篇文章主要介紹Javascript將數(shù)字轉(zhuǎn)化成為貨幣格式字符串的方法,通俗易懂,需要的朋友可以參考下。2016-06-06
el-table el-table-column表頭嵌套循環(huán)數(shù)據(jù)的示例代碼
本文介紹了使用兩個數(shù)組來實現(xiàn)el-table中表頭的嵌套循環(huán),一個數(shù)組用于循環(huán)表格數(shù)據(jù),另一個用于循環(huán)表頭,幫助讀者更好地理解和應(yīng)用表頭嵌套功能,感興趣的朋友跟隨小編一起看看吧2024-09-09
使用JavaScript實現(xiàn)文本收起展開(省略)功能
省略號,作為一種常見的文本處理方式,在很多情況下都十分常見,特別是當(dāng)我們需要在省略號后面添加額外文字時,本文為大家介紹了使用JavaScript實現(xiàn)文本收起展開功能的相關(guān)方法,希望對大家有所幫助2024-04-04
JavaScript 復(fù)制對象與Object.assign方法無法實現(xiàn)深復(fù)制
這篇文章主要介紹了JavaScript 復(fù)制對象與Object.assign方法無法實現(xiàn)深復(fù)制,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11
JS/HTML5游戲常用算法之碰撞檢測 包圍盒檢測算法詳解【矩形情況】
這篇文章主要介紹了JS/HTML5游戲常用算法之碰撞檢測 包圍盒檢測算法,結(jié)合實例形式詳細(xì)分析了游戲算法中針對碰撞檢測的包盒矩形情況下的相關(guān)算法原理與操作注意事項,需要的朋友可以參考下2018-12-12

