不要在vue中使用jsx

配置

新项目

npm create vue命令中设置jsx即可在项目中使用jsx

已有项目(vite)

vite.config.js中增加插件

js 复制代码
import vueJsx from '@vitejs/plugin-vue-jsx'

export default defineConfig({
  plugins: [
  // ...
    vueJsx(),
  ],
})

写法

javascript 复制代码
// App.jsx
import { defineComponent, ref } from "vue";

const Comp = defineComponent({
  props: ["onClick"],
  setup(props, { slots }) {
    return () => (
      <button onClick={props.onClick}>{slots.default?.() ?? "a"}</button>
    );
  },
});

const App = defineComponent({
  setup() {
    const num = ref(0);
    return () => <Comp onClick={() => num.value++}>{num.value}</Comp>;
  },
});

export default App;

说明

  1. setup的返回值是一个render函数 ()=>jsx 而不是普通的jsx 可以理解成react类组件中的render函数
  2. setup函数的签名是setup(props,{ slots, emit, attrs }) 但仅推荐使用props和slots
  3. 传入的onClickclass等会被自动应用到子组件的最外层 需要设置inheritAttrs:false
  4. 上述的参数会被收集至setupattrs参数中,需要设置props: ["onClick"]才会识别为props.这种情况下,不需要配置inheritAttrs:false
  5. 插槽位于slots对象中,类型是函数,用法是
arduino 复制代码
{slots.default?.() ?? default-view}

default是默认插槽的名字 如果有其他的具名插槽 使用slots.插槽名即可

插槽函数可以传递参数 和template中插槽功能一样

  1. jsx方式中 只能传输不带参数的默认插槽 类似于react中的children参数

  2. jsx方式中 这种写法依旧是不行的

css 复制代码
Modal.info({ content: <span></span> })

必须使用h('span')

ts

vue+jsx姑且能用 但是vue+tsx就相当恶心了

ts中 传onClick得这么做

typescript 复制代码
import type { PropType } from 'vue'

defineComponent({
  props: {
    onClick: Function as PropType<()=> void>
  },
  setup(props, { slots }) {
    //...
  },
});

可以设置defineComponent的模板类型 但是还是会导致onClick被自动应用到子组件最外层以及被视作attrs

插槽方面应该也有一些问题 不过劝退的理由不需要太多 原先的一堆问题再加这个已经足够了

总结

本文的标题其实一开始是在vue中使用jsx 我之前对这种写法是抱有很多期待的 心理流程大概是这样的

  • ref非常方便 本体和属性都能直接传给v-model hook限制好少 有点爽
  • v-model不好 至少element ui里使用体验极差 组件不听话
js 复制代码
<el-tabs modelValue="0">
    <el-tab-pane name="0"></el-tab-pane>
    <el-tab-pane name="1"></el-tab-pane>
</el-tabs>

我都这么写了 它还是能自由切换 是真不愿意受控啊

  • vue+jsx能把refvalue-onChange模式结合起来 还能不用写那该死的:@# 简直是vue和react的融合超进化 值得一试
  • 一坨

又回过头来看最开始的那个想法 ref其实也没那么好

我需要找一个变量被更新的位置 并没有一个专用的setState 我得查看那个变量被引用的所有位置 无论是取值还是设置

话又说回来 有use-immer react的状态更新还是很方便的

hook方面 有eslint其实还好 而且只要把文档记在心中 其实也很难犯错

至于效率问题 现代浏览器一般不会有这方面的问题 真卡顿再优化也不迟

vue项目一坨一坨盘根错节的组件也不少 不见得比react好到哪里去

相关推荐
LYFlied21 分钟前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
B站_计算机毕业设计之家1 小时前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
xjt_09012 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农2 小时前
Vue 2.3
前端·javascript·vue.js
跳动的梦想家h3 小时前
环境配置 + AI 提效双管齐下
java·vue.js·spring
Mr Xu_4 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
AAA阿giao4 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
一 乐5 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
科技D人生5 小时前
Vue.js 学习总结(20)—— Vue-Office 实战:word、pdf、excel、ppt 多种文档的在线预览
vue.js·word·vue-pdf·stylesheet·docx-preview·vue-office
vx1_Biye_Design5 小时前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven