抢 React 饭碗!如何在 Vue3 中使用 JSX & TSX

首先,恭喜一下 React,再过 4 个月,就达成了两年无更新记录

反观隔壁的 Vue,稳定迭代更新

之前写 React 的时候,最喜欢的是 JSX/TSX 语法,把 HTML 组件当做 JavaScript/TypeScript 代码片段处理

ts 复制代码
const App: React.FC<AppProps> = ({ title }) => {
  const [count, setCount] = useState<number>(0);
  // 👇👇👇
  return (
    <div>
      <h1>{title}</h1>
      <p>You clicked {count} times</p>
      <button onClick={() => setCount(count + 1)}>
        Click me
      </button>
    </div>
  );
}

转战 Vue 之后,最痛苦的是没办法利用 TSX 语法灵活创建组件。

最常见的例子是,当我有一个数据表格,需要自定义字段的组件时,得用 h() 函数来创建:

ts 复制代码
<script lang="ts" setup>
//...
const createColumns = () => {
  return [
    {
      title: 'Action',
      key: 'actions',
      render (row) {
        /* 👇👇👇 */
        return h(
          NButton,
          {
            strong: true,
            tertiary: true,
            size: 'small',
            onClick: () => play(row)
          },
          { default: () => 'Play' }
        )
      }
    }
  ]
}
//...
</script>

h() 麻烦,低频使用情况下,每次都得查一遍文档。

最近发现 Vue3 原来是支持 JSX & TSX 的!

👉 官方文档: vuejs.org/guide/extra...

在 Vue3 中集成 JSX & TSX 相对简单,安装插件:

bash 复制代码
npm install @vue/babel-plugin-jsx -D

将 babel 文件中配置:

json 复制代码
{
  "plugins": ["@vue/babel-plugin-jsx"]
}

如果项目用 TypeScript,则在 tsconfig.json 中配置:

json 复制代码
{
  "compilerOptions": {
    "jsx": "preserve"
  }
}

📝 注意:这里以 babel 举例,如果是其他工具链,比如 Vite、Nuxt 的话,请参考对应文档。

集成之后,上述的 h() 终于可以扔掉,换回熟悉的 JSX & TSX:

ts 复制代码
<script lang="ts" setup>
//...
const createColumns = () => {
  return [
    {
      title: 'Action',
      key: 'actions',
      render (row) {
        /* 👇👇👇 */
        return (
          <NButton 
            strong={true}
            tertiary={true}
            size="small"
            onClick={() => play(row)}>
            Play
          </NButton>
        )
      }
    }
  ]
}
//...
</script>

Vue3,你是懂框架的,妥妥的真香。

Vue 的诞生,已经十个年头,这么些年来,Vue 始终稳步前进

降低开发成本和心智负担方面来说,Vue 算得上优秀。

先后推出的 Composition API、Setup、支持 TSX 语法等,真正的理解、赋能开发者

值得一提的是,国内的开发者确实偏爱 Vue,不论是 Star 人数、Issue 数量 和 Pull Request 数量,都是遥遥领先:

数据来源:ossinsight.io/analyze/vue...

最后推荐一些好用的资源

👉 程序员楷鹏,如果有任何前端、 AI 方向的问题,可以在这个公众号上联系到我

👉 wukaipeng.com,上面收录个人所有的技术和英语博客,这个博客网站在 GitHub 开源,基于最新的 Docusaurus3,欢迎 star

👉 doc.starflow.tech 专门面向中文的提示词工程指南,同样开源,一起学习进步

相关推荐
pixle01 小时前
Web大屏适配终极方案:vw/vh + flex + clamp() 完美组合
前端·大屏适配·vw/vh·clamp·终极方案·web大屏
ssf19871 小时前
前后端分离项目前端页面开发远程调试代理解决跨域问题方法
前端
@PHARAOH1 小时前
WHAT - 前端性能指标(加载性能指标)
前端
尘世中一位迷途小书童1 小时前
🎨 SCSS 高级用法完全指南:从入门到精通
前端·css·开源
非凡ghost1 小时前
火狐浏览器(Firefox)tete009 Firefox 多语便携版
前端·firefox
文心快码BaiduComate1 小时前
文心快码Comate3.5S更新,用多智能体协同做个健康管理应用
前端·人工智能·后端
袁煦丞1 小时前
极空间变身全能私有云+1Panel傻瓜式部署:cpolar内网穿透实验室第618个成功挑战
前端·程序员·远程工作
袁煦丞1 小时前
10.15-1 Reader电子书管理神器搭配极空间私有云:cpolar内网穿透实验室第488个成功挑战
前端·程序员·远程工作
ZHOUYUANN2 小时前
我用JavaScript复刻了某宝的小游戏动物大迁徙消消乐
前端·javascript·游戏开发
Asort2 小时前
JavaScript设计模式(十三)——责任链模式:构建灵活高效的请求处理链
前端·javascript·设计模式