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

  • 苹果13吃鸡能开90帧吗(苹果13吃鸡能开极清吗)

    苹果13吃鸡能开90帧吗(苹果13吃鸡能开极清吗)

  • 华为抬起亮屏怎么设置(华为抬起亮屏怎么设置mate20)

    华为抬起亮屏怎么设置(华为抬起亮屏怎么设置mate20)

  • 页脚文字怎么设置(页脚文字怎么设计)

    页脚文字怎么设置(页脚文字怎么设计)

  • 苹果a2031第几代(apple a2031是什么版本的airpod)

    苹果a2031第几代(apple a2031是什么版本的airpod)

  • 为什么soul瞬间会限流(为什么soul瞬间发不出去)

    为什么soul瞬间会限流(为什么soul瞬间发不出去)

  • 淘宝投诉撤销后还可以再次投诉吗(淘宝投诉撤销后还能再次发起投诉吗)

    淘宝投诉撤销后还可以再次投诉吗(淘宝投诉撤销后还能再次发起投诉吗)

  • office打不开显示正在更新(office打不开显示内存不足)

    office打不开显示正在更新(office打不开显示内存不足)

  • 手机屏幕不能亮了怎么办(手机屏幕不能亮但是能触屏)

    手机屏幕不能亮了怎么办(手机屏幕不能亮但是能触屏)

  • 淘宝店铺装修分为哪几个模块(淘宝店铺装修分为几部分)

    淘宝店铺装修分为哪几个模块(淘宝店铺装修分为几部分)

  • 笔记本电脑耳机和手机耳机一样吗(笔记本电脑耳机插上没声音)

    笔记本电脑耳机和手机耳机一样吗(笔记本电脑耳机插上没声音)

  • 为啥手机发烫(充电为啥手机发烫)

    为啥手机发烫(充电为啥手机发烫)

  • 苹果se关机充电不显示充电(苹果se关机充电不显示电量)

    苹果se关机充电不显示充电(苹果se关机充电不显示电量)

  • 打印用rgb还是cmyk(打印rgb颜色打印会对吗?)

    打印用rgb还是cmyk(打印rgb颜色打印会对吗?)

  • 华为p40pro怎么省电(华为p40pro怎么省点)

    华为p40pro怎么省电(华为p40pro怎么省点)

  • 手机后面的玻璃碎了(手机后面的玻璃碎了可以修吗)

    手机后面的玻璃碎了(手机后面的玻璃碎了可以修吗)

  • 苹果手机最上面一排不见了(苹果手机最上面的横槽是什么)

    苹果手机最上面一排不见了(苹果手机最上面的横槽是什么)

  • 红米k20pro到底要不要贴膜(全新红米k20pro)

    红米k20pro到底要不要贴膜(全新红米k20pro)

  • 魅族16thplus充电接口(魅族16thplus充电器多少w)

    魅族16thplus充电接口(魅族16thplus充电器多少w)

  • 手机qq咋取消文件默认(手机qq咋取消文字提示)

    手机qq咋取消文件默认(手机qq咋取消文字提示)

  • 一加七手机配什么耳机(一加七手机配什么充电器)

    一加七手机配什么耳机(一加七手机配什么充电器)

  • 苹果手机怎么设置陌生号电话信息进不来(苹果手机怎么设置呼叫转移功能)

    苹果手机怎么设置陌生号电话信息进不来(苹果手机怎么设置呼叫转移功能)

  • 苹果不激活可以验机吗(苹果不激活可以使用吗?)

    苹果不激活可以验机吗(苹果不激活可以使用吗?)

  • 小翼管家怎么绑定网关(小翼管家怎么绑定路由器)

    小翼管家怎么绑定网关(小翼管家怎么绑定路由器)

  • 中国手机为什么不用北斗卫星(中国手机为什么不能用谷歌)

    中国手机为什么不用北斗卫星(中国手机为什么不能用谷歌)

  • ps全屏快捷键(ps所有快捷键)

    ps全屏快捷键(ps所有快捷键)

  • 承兑汇票私人贴现要多久
  • 增值税普通发票几个点
  • 记账凭证如何填写明细科目
  • 一般纳税人什么时候用简易计税
  • 申报表季初资产和季末资产
  • 工业企业所得税优惠政策
  • 怎么确定印花税申报成功
  • 允许税前扣除的利息支出
  • 简易征收应纳税额计算
  • 现金支票提取现金备用
  • 公司改变工资结构变相降工资怎么办
  • 工程材料增值税专用发票税率
  • 企业增加实收资本
  • 出租厂房的摊销额会计分录
  • 每月计提折旧
  • 不能税前扣除的费用有哪些
  • 稳定性流动资产是经营性流动资产吗
  • 母公司给子公司担保需要决议吗
  • 进口关税完税价格
  • 发票边上的虚线是什么
  • 不申报税务登记被注销
  • 加计扣除是什么优惠方式
  • 销方开具红字发票流程
  • 企业员工自行体检流程
  • 房地产开发企业的土地使用权计入哪里
  • 职工领取企业年金税收优惠
  • 增值税发票为什么要勾选认证
  • 王者荣耀中苏烈的最强出装
  • 免抵退税的账务处理
  • 失业保险稳岗补贴是什么意思
  • 罗汉松的养殖方法剪枝视频
  • 利得的具体分类
  • 暂估入账的固定资产可以计提折旧吗
  • php中自定义常量的函数是
  • 融资租赁利息资本化条件
  • 什么叫财政专户返还方式
  • 股东以固定资产入股需要交税吗
  • javaweb简单项目案例
  • 测试费计入什么会计科目
  • 毕业设计基于Linux系统的NFS服务器搭建
  • pytorch nn.parameters
  • 高新技术企业研发费用加计扣除
  • 纸质增值税专用发票申领
  • SQL SERVER 将XML变量转为JSON文本
  • 接受捐赠的固定资产怎么计提折旧
  • 一般纳税人资格证明在哪里查询
  • 出售固定资产不能作为企业的收入
  • 应收应付会计分录大全
  • 补贴收入是否缴纳个税
  • 社保当月没扣
  • 企业所得税几种税率
  • 对公账户收到钱都要开票吗
  • 电脑配件入账
  • 核定征收每月最低交多少税
  • 售后回租含手续费吗
  • 坐车时的保险费怎么算
  • 收入的确认条件包括
  • 资产负债表资产按照什么顺序
  • 半个固定资产如何折旧
  • 产值和销售收入可以一样吗
  • 五险怎么做账
  • 商业企业长期负债怎么办
  • mysql 5.5 5.6
  • mysql安装配置教程5.7.25
  • ubuntu 20.04拨号上网
  • macpro删除文件
  • pavprot.exe - pavprot是什么进程 作用是什么
  • win10系统开机桌面图标不见了
  • win7系统怎么关闭屏幕保护
  • unity拖进模型什么也看不到
  • shell脚本实现批量移动文件
  • javascript绘制图形
  • android之handler
  • python生成txt文档
  • jquery获取自定义标签的值
  • java在android上运行
  • 遍历字符串python
  • 红字专用发票进什么科目
  • 税务审理工作总结
  • 云南省国家税务局电子税务局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设