vue 渲染函数 h & jsx

h 是什么

vue 提供的创建虚拟 DOM 节点 (vnode)的函数。

https://cn.vuejs.org/api/render-function.html#h

jsx 是什么

JSX是 JavaScript XML(HTML)的缩写,表示在 JS 代码中书写 HTML 结构。简单理解就是: JSX=javascript xml(HTML) ,是 JavaScript 的语法扩展,只要你把HTML代码写在JS里,那就是JSX。

h和jsx的关系

vue文件中的template部分最终会编译成虚拟dom,h函数生成的是虚拟dom,jsx通过jsx的编译插件生成的也是虚拟dom,所以,h和jsx是生成虚拟dom的两种方式,又由于jsx更贴近于html与传统的template结构,jsx提供了更高的可读性

另外部分有react基础的同学,可能也更加喜欢jsx

什么时候要用 h | jsx

一:在一些特定场景下,使用 h(JSX)去编写页面会比使用模板语法简单且逻辑更清晰,可以使页面渲染逻辑与判断逻辑更好的绑定在一起。在对于一些代码量较少但重复性较高的片段,使用 h(JSX)可以做到更好的代码复用。
示例:

有这样一个组件,需要通过传入的 Level 去生成不同级别的标题,如果使用模板语法,那可能会需要这样写:

javascript 复制代码
<template> 
  <h1 v-if="level === 1">{{ title }}</h1>
  <h2 v-if="level === 2">{{ title }}</h2>
  <h3 v-if="level === 3">{{ title }}</h3>
</template>
javascript 复制代码
const LevelTag = ({ level }) => { 
  const Tag = `h${level}` 
  return <Tag>123</Tag> 
} 
return <LevelTag level={level} />
二:一些组件库内属性可以传入 vnode 的时候,有可能需要用到 h(JSX)

@arco.design 中的几个组件

Modal

notification

message

table

三:UI图里有一些稍微复杂的弹窗


vue3渲染函数(h函数)的变化-阿里云开发者社区 vue3渲染函数(h函数)的变化 https://developer.aliyun.com/article/1410904

相关推荐
Jagger_15 分钟前
Cursor + Apifox MCP:告别手动复制接口,AI 助你高效完成接口文档开发
前端
IT_陈寒31 分钟前
Redis性能优化:5个被低估的配置项让你的QPS提升50%
前端·人工智能·后端
Hilaku37 分钟前
重新思考CSS Reset:normalize.css vs reset.css vs remedy.css,在2025年该如何选?
前端·css·代码规范
袁煦丞1 小时前
一图看懂Docker管理 Portainer:cpoar内网穿透实验室第652个成功挑战
前端·程序员·远程工作
右子1 小时前
微信小程序开发“闭坑”指南
前端·javascript·微信小程序
AGG_Chan1 小时前
flutter专栏--深入了解widget原理
开发语言·javascript·flutter
冰镇生鲜1 小时前
前端模拟 流式文本接口 打字机效果 mockStreamText
javascript
入秋1 小时前
Three.js后期处理实战:噪点 景深 以及色彩调整
前端·javascript·three.js
Asort2 小时前
JavaScript设计模式(七)——桥接模式:解耦抽象与实现的优雅之道
前端·javascript·设计模式
golang学习记2 小时前
从0死磕全栈之Next.js 应用中的认证与授权:从零实现安全用户系统
前端