位置: 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 常用命令大全及其详解)

  • 企业所得税属于地方税吗
  • 小规模纳税人一般纳税人区别
  • 留抵税额是什么意思啊
  • 待认证进项税账务处理
  • 外商投资合伙企业的性质与特征
  • 社保本期工资总额是怎么填的
  • 借款当月算利息吗
  • 固定资产累计折旧是什么科目
  • 申报成功忘记清关怎么办
  • 进项税发票认证期限多长时间
  • 企业合并股份比例
  • 房地产企业可以开专票吗
  • 新个税工资薪金和综合所得
  • 短期薪酬是会计科目么
  • 应付账款 暂估
  • 劳务费个人还需要交税吗
  • 购买免税苗木抵税分录
  • 货物销售价比采购价高
  • 广告公司怎么结转成本
  • 如果在XP系统中QQ音乐听不了怎么办?
  • 如何修改windows11开机密码
  • 领用原材料业务
  • 收回已核销的坏账并入账
  • 不附追索权的票据包括
  • 外贸公司进出口权办理流程
  • 内置管理员无法激活
  • remupd.exe - remupd是什么进程 有什么用
  • 最轻薄数码相机
  • 跨年度退货
  • 中科院院士2023增选
  • php日期计算器
  • 金蝶利润表主营业务成本公式
  • 房地产企业销售佣金税前扣除
  • 程序员神器
  • 前端vue面试题
  • 命令行改gpt
  • 计算工业总产值公式
  • 什么是企业管理的首要职能
  • 年底应交增值税借方余额怎么处理
  • 企业年报未报会有什么后果
  • python 进程pid
  • mysql写日志机制
  • 帝国cms8.0
  • 非货币交易分录
  • 税控系统减免税
  • 房地产开发企业成本核算方法
  • 对公转账需要填备注吗
  • 固定资产加速折旧是什么意思
  • 酒店购买天然气开票的摘要写什么
  • 金税盘分盘可以全额抵扣吗
  • 其他应收款账务核销后放在哪个科目里
  • 冲以前年度成本分路
  • 残保金是第二年交前一年的吗
  • 企业营业外支出是什么意思
  • 有会计从业资格证还有用吗
  • 建账有几种方法
  • 建造固定资产的账务处理(出包方式)
  • sqlserver响应好慢
  • windows内存诊断是干什么的
  • win7与ubuntu双系统
  • vmwares
  • 正常关机开机后爱奇艺自动卸载
  • win10系统回收站损坏了怎么恢复
  • 360win7
  • linux服务器常用命令
  • Win7系统如何开启移动到文件夹选项
  • 系统恢复 win10
  • debian linux教程
  • linux系统怎么更改语言
  • javascript运用
  • jquery animation
  • jquery实现手风琴遇到问题
  • 搭建nfs
  • docker编写dockerfile
  • 事件的分发与传播的关系
  • 国家河北税务局官网
  • 朝阳税务总局
  • 房产税纳税义务时间
  • 社保申报每月几号申报
  • 2018年3月增值税申报期限
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设