位置: IT常识 - 正文

vue3中如何使用JSX?(vue3中如何使用vuex)

编辑:rootadmin
vue3中如何使用JSX?

推荐整理分享vue3中如何使用JSX?(vue3中如何使用vuex),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3中如何使用钩子函数?,vue怎么使用js,vue3中如何使用rxjs,vue3中如何使用rxjs,vue3中如何使用截流防抖,vue3中如何使用rxjs,vue3中如何使用vue2,vue3中如何使用截流防抖,内容如对您有帮助,希望把文章链接给更多的朋友!

在绝大多数情况下,Vue 推荐使用模板<template>语法来创建应用。

在 Vue 3 的项目开发中,template 是 Vue 3 默认的写法。虽然 template 长得很像 HTML,但 Vue 其实会把 template 解析为 render 函数,之后,组件运行的时候通过 render 函数去返回虚拟 DOM。

然而在某些使用场景下,我们真的需要用到 JavaScript 完全的编程能力。这时渲染函数就派上用场了。

h函数

Vue 提供了一个 h() 函数用于创建 vnodes虚拟dom。如下示例:

import { h } from 'vue'const vnode = h('div', // type{ id: 'foo', class: 'bar' }, // props[/* children */])

在组件中如何使用呢?

之前当组合式 API 与模板一起使用时,setup() 钩子的返回值是用于暴露数据给模板。但是当使用h()的时候,setup() 钩子返回的是渲染函数:

import { ref, h } from 'vue'export default {props: {/* ... */},setup(props) {const count = ref(1)// 返回渲染函数return () => h('div', props.msg + count.value)}}

手写的 h 函数,可以处理动态性更高的场景。但是如果是复杂的场景,h 函数写起来就显得非常繁琐,需要自己把所有的属性都转变成对象。并且组件嵌套的时候,对象也会变得非常复杂。不过,因为 h 函数也是返回虚拟 DOM 的,所以有没有更方便的方式去写 h 函数呢?答案是肯定的,这个方式就是 JSX。

JSX

JSX 是 JavaScript 的一个类似 XML 的扩展,有了它,我们可以用简单方式来创建vnodes:

const vnode = <div id="app">hello</div>

这种在 JavaScript 里面写 HTML 的语法,就叫做 JSX,算是对 JavaScript 语法的一个扩展。上面的代码直接在 JavaScript 环境中运行时,会报错。JSX 的本质就是下面代码的语法糖。

const vnode = createVnode('div',{id:"app"}, 'hello')

其实h 函数内部也是调用 createVnode 来返回虚拟 DOM。

那么,如何在Vue项目中使用JSX呢?

默认的情况下,vue3+vite的项目不支持jsx,如果想支持jsx,需要安装插件@vitejs/plugin-vue-jsx

安装

npm i @vitejs/plugin-vue-jsx -D

在vite.config.js中进行配置:

import vueJsx from "@vitejs/plugin-vue-jsx"; // 配置vue使用jsxexport default defineConfig({plugins: [vue(), vueJsx()],}); vue3中如何使用JSX?(vue3中如何使用vuex)

然后就可以在Vue组件中使用了:

// render.vue<script lang="jsx"> import { ref } from "vue";export default {setup() {const count = ref(100);return () => <div>count is: {count.value}</div>;},}; </script>

注意:script中lang要改成jsx。

或者是一个jsx文件:

// render.jsximport { defineComponent } from 'vue'export default defineComponent({setup() {return () => <div>jsx文件</div>}}) Template vs JSX

我们该怎么选择 JSX 和 template 呢?

template优势:template 的语法是固定的,只有 v-if、v-for 等等语法。我们按照这种固定格式的语法书写,这样 Vue3 在编译层面就可以很方便地去做静态标记的优化,减少Diff过程。比如静态提升,类型标记,树结构打平等来提高虚拟 DOM 运行时性能。这也是 Vue 3 的虚拟 DOM 能够比 Vue 2 快的一个重要原因。

JSX优势:template 则因为语法限制原因,不能够像 JSX 那样可以支持更动态的需求。这也是 JSX 相比于 template 的一个优势。

JSX 相比于 template 还有一个优势,是可以在一个文件内返回多个组件。

那如何选择呢?

在实现业务需求的时候,优先使用 template,尽可能地利用 Vue 本身的性能优化。而对于动态性要求较高的组件可以使用 JSX 来实现。(比如后面,我会用JSX来实现动态表单生成器)

总结

首先,我们在项目中通常使用template模板来创建应用,template模板会在构建阶段被编译成render渲染函数。渲染函数就是用来返回虚拟DOM的函数。

那么我们其实可以跳过这个步骤,直接使用h函数来生成虚拟DOM。

h函数的内部执行的其实是createVNode函数来生成虚拟DOM的,但是由于h函数比较难写,所以我们使用JSX来更加方便快捷的书写。JSX的内部其实也是使用的createVNode函数。

JSX在JavaScript中是不能直接执行的,在vite项目中,我们需要安装插件@vitejs/plugin-vue-jsx

,并进行相应配置才可以。

最后对比了template和JSX的优劣势。template的优势在于语法固定,容易书写,并且在编译层面Vue3对template的编译做了很多优化。而JSX胜在灵活性,在某些动态性要求较高的情况下,JSX成了标配。

所谓,术业有专攻,template和JSX没有谁比谁更厉害的存在,在不同场景下各有优劣,用好了都是编程利器。

最后

最近找到一个VUE的文档,它将VUE的各个知识点进行了总结,整理成了《Vue 开发必须知道的36个技巧》。内容比较详实,对各个知识点的讲解也十分到位。

有需要的小伙伴,可以点击下方卡片领取,无偿分享

本文链接地址:https://www.jiuchutong.com/zhishi/300144.html 转载请保留说明!

上一篇:深度卷积神经网络(AlexNet)(深度卷积神经网络基本结构)

下一篇:linux常用命令大全(linux 常用命令大全及其详解)

  • 个体工商户需要进项发票吗
  • 利润表中的所得税
  • 经营性应付项目的增加怎么计算
  • 党建经费的标准
  • 个税申报导入上月数据
  • 小微企业免增值税2023年政策
  • 个人如何开现金账户
  • 专票未认证是什么意思
  • 固定资产后续支出资本化条件是什么
  • 出租不动产房屋交什么税
  • 公司转工程款到个人银行卡需要交个税吗
  • 承兑到期没兑现怎么处理
  • 诉讼财产保全保险费能否主张
  • 预支的采购备用金是什么
  • 公司为员工每月几号缴社保
  • 个人承包经营所得是什么意思
  • 在建工程安装工程包括
  • 营改增之后的增值税
  • 对公账户钱怎么退回去
  • 没有收款人复核人的发票能报销吗
  • 小规模税务30万免税政策
  • 开错的发票正常入账吗
  • 汇算清缴需要补税
  • 收到退印花税款怎么入账
  • 福利企业的增值税是多少
  • 公司账上收到职工的生育津贴如何做账?
  • 财务报表年报和季报必须一样吗
  • 政府性基金预算收入包括
  • 上月的应付账款怎么记账
  • 账面上挂的其他应付款怎么冲平?
  • 如何修改系统时间为12/24小时制
  • 经济作物国家有什么补助吗
  • 无票费用 规定
  • win11多开
  • 房产税的应纳税额计算方法
  • vue数据更新会触发什么生命周期
  • php 文件系统
  • 温哥华瀑布
  • 进口货物完税价格怎么算
  • 溢价收购股权会计处理案例
  • mvc与mvvm
  • 应收利息的会计处理方法
  • 利润分配的账务处理会计分录
  • 企业没有研发费用怎么做账
  • 无偿划转股权涉税
  • 福利费用使用范围
  • 出售固定资产不确认收入
  • 一个分组名称
  • var文件是什么意思
  • 小规模年度企业所得税纳税申报表
  • 发票可否盖财务章
  • 暂估入账的固定资产
  • 制造费用的明细账应当按照什么设置
  • 风险纳税人去税务局去报税可以吗
  • 预缴所得税弥补以前年度亏损
  • 大金额维修费用怎么入账
  • 小企业的建账流程
  • mysql用中文字段
  • [视频回复]
  • 怎么提升命令提示符
  • win10预览版选哪个
  • 怎样恢复显示桌面图标
  • ubuntu多桌面切换
  • window7优盘不显示
  • win10应用默认
  • 手机如何使用windows
  • win7注册表详解
  • win7系统开机黑屏如何处理
  • android怎么保存项目
  • 网页设计绿色
  • Android AsyncTaskLoader需要注意的问题
  • 请问在javascript程序中
  • 使用BMFont+NGUI利用图片制作自定义字体
  • Unity3D游戏开发培训课程大纲
  • W3C Group的JavaScript1.8 新特性介绍
  • python 描述符类
  • JavaScript和HTML DOM的区别与联系及Javascript和DOM的关系
  • python爬取三国演义前六章
  • javascript网页编程
  • 计算出口退税的免抵税额,不计征城市维护建设税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设