Vue3中使用jsx/tsx的教程详解

 更新时间:2024年02月13日 09:04:27   作者:吴楷鹏  
这篇文章主要为大家详细介绍了如何在Vue3中使用jsx/tsx的相关知识,文中的示例代码讲解详细,具有一定的借鉴价值,需要的小伙伴可以了解下

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

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

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

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() 函数来创建:

<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/extras/render-function.html#jsx-tsx

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

npm install @vue/babel-plugin-jsx -D

将 babel 文件中配置:

{
  "plugins": ["@vue/babel-plugin-jsx"]
}

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

{
  "compilerOptions": {
    "jsx": "preserve"
  }
}

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

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

<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/vuejs/core#people

到此这篇关于Vue3中使用jsx/tsx的教程详解的文章就介绍到这了,更多相关Vue3使用jsx/tsx内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 如何用vue-pdf包实现pdf文件预览,支持分页

    如何用vue-pdf包实现pdf文件预览,支持分页

    这篇文章主要介绍了如何用vue-pdf包实现pdf文件预览,支持分页问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Template ref在Vue3中的实现原理详解

    Template ref在Vue3中的实现原理详解

    这篇文章主要为大家介绍了Template ref在Vue3中的实现原理示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • vue下载excel的实现代码后台用post方法

    vue下载excel的实现代码后台用post方法

    这篇文章主要介绍了vue下载excel的实现代码,后台用post方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2019-05-05
  • vue axios封装及API统一管理的方法

    vue axios封装及API统一管理的方法

    这篇文章主要介绍了vue axios封装以及API统一管理 ,需要的朋友可以参考下
    2019-04-04
  • vue实现双向绑定和依赖收集遇到的坑

    vue实现双向绑定和依赖收集遇到的坑

    这篇文章主要介绍了vue的双向绑定和依赖收集,主要是通过Object.defineProperty() 实现双向绑定,具体思路代码大家跟随小编一起看看吧
    2018-11-11
  • vue回到顶部监听滚动事件详解

    vue回到顶部监听滚动事件详解

    这篇文章主要为大家详细介绍了vue回到顶部监听滚动事件,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • Vue3+Vite+TS使用elementPlus时踩的坑及解决

    Vue3+Vite+TS使用elementPlus时踩的坑及解决

    这篇文章主要介绍了Vue3+Vite+TS使用elementPlus时踩的坑及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • Vue vee-validate插件的简单使用

    Vue vee-validate插件的简单使用

    这个插件可以用来在未使用组件库,没有自带好的校验规则时使用,进行表单校验,非常的实用,感兴趣的朋友可以参考下本文,了解该插件的使用方法
    2021-06-06
  • defineProperty和Proxy基础功能及性能对比

    defineProperty和Proxy基础功能及性能对比

    这篇文章主要为大家介绍了defineProperty和Proxy基础功能及性能对比,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • vue中引用阿里字体图标的方法

    vue中引用阿里字体图标的方法

    这篇文章主要介绍了vue中引用阿里字体图标出现错误问题的解决方法,感兴趣的朋友跟随脚本之家小编一起学习吧
    2018-02-02

最新评论