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

  • vivox605g开关在哪(vivox60pro5g开关在哪个地方)

    vivox605g开关在哪(vivox60pro5g开关在哪个地方)

  • oppoa56怎么录屏操作方法(oppoa56怎么录屏幕视频带声音)

    oppoa56怎么录屏操作方法(oppoa56怎么录屏幕视频带声音)

  • 坦白局能知道对方是谁吗(坦白局之后是什么局)

    坦白局能知道对方是谁吗(坦白局之后是什么局)

  • 已信任的app删除后无法安装(已信任的app删除不了)

    已信任的app删除后无法安装(已信任的app删除不了)

  • 手机下面三个键叫什么(手机下面三个键怎么调出来vⅰvo)

    手机下面三个键叫什么(手机下面三个键怎么调出来vⅰvo)

  • 华为平板5g什么时候上市(华为平板5g有用吗)

    华为平板5g什么时候上市(华为平板5g有用吗)

  • 华为触屏时有个小圆圈(华为触屏时有个圆点怎么关闭)

    华为触屏时有个小圆圈(华为触屏时有个圆点怎么关闭)

  • prog键是什么意思(prog啥意思)

    prog键是什么意思(prog啥意思)

  • 小米手环3显示请先绑定怎么办(小米手环3显示已充满电就是开不了屏)

    小米手环3显示请先绑定怎么办(小米手环3显示已充满电就是开不了屏)

  • khealtheye是什么(kelsey是什么意思)

    khealtheye是什么(kelsey是什么意思)

  • 闲鱼拒收卖家不同意怎么办(闲鱼拒收卖家不退款卖家又收到货了)

    闲鱼拒收卖家不同意怎么办(闲鱼拒收卖家不退款卖家又收到货了)

  • 换sim卡要钱吗(营业厅换sim卡要钱吗)

    换sim卡要钱吗(营业厅换sim卡要钱吗)

  • 微信怎么设置仅一人可见(微信怎么设置仅你可见)

    微信怎么设置仅一人可见(微信怎么设置仅你可见)

  • 平板保修期多久(华为平板保修期多久)

    平板保修期多久(华为平板保修期多久)

  • 华为手机人工智能叫什么(华为手机人工智能语音助手怎么打开)

    华为手机人工智能叫什么(华为手机人工智能语音助手怎么打开)

  • 把十进制数215转换成二进制数是(十进制数215转换成八进制数是)

    把十进制数215转换成二进制数是(十进制数215转换成八进制数是)

  • 苹果手机电筒不亮了怎么办(苹果手机电筒不能打开)

    苹果手机电筒不亮了怎么办(苹果手机电筒不能打开)

  • 优酷会员怎么踢人下线(优酷会员怎么踢出其他设备)

    优酷会员怎么踢人下线(优酷会员怎么踢出其他设备)

  • 笔记本怎么恢复系统还原(笔记本怎么恢复成原装系统)

    笔记本怎么恢复系统还原(笔记本怎么恢复成原装系统)

  • 计算器ac是什么键(计算器ac是什么的缩写)

    计算器ac是什么键(计算器ac是什么的缩写)

  • iphonex的3dtouch在哪

    iphonex的3dtouch在哪

  • oppo手机拍照怎么打开夜景模式(oppo手机拍照怎么设置全屏)

    oppo手机拍照怎么打开夜景模式(oppo手机拍照怎么设置全屏)

  • 抖音怎么发声控类视频(在抖音上怎么弄声控)

    抖音怎么发声控类视频(在抖音上怎么弄声控)

  • 哈罗单车关锁在哪里(哈罗单车关锁怎么关)

    哈罗单车关锁在哪里(哈罗单车关锁怎么关)

  • 苹果可以用oppo闪充吗(苹果可以用oppowatch吗)

    苹果可以用oppo闪充吗(苹果可以用oppowatch吗)

  • bootmgriscopressed怎么解决

    bootmgriscopressed怎么解决

  • Word如何删除空白页(word如何删除空白表格)

    Word如何删除空白页(word如何删除空白表格)

  • 表格拆分数字和文字

    表格拆分数字和文字

  • YOLOv5输出端损失函数(yolov3输出是什么)

    YOLOv5输出端损失函数(yolov3输出是什么)

  • 下载 | CactiEZ 中文版(calc下载)

    下载 | CactiEZ 中文版(calc下载)

  • 增值税影响利润总额吗
  • 研发费用加计扣除是什么意思啊
  • 转租仓库交增值税吗
  • 减免增值税计入其他收益
  • 股东退股如何清算表格
  • 其他应收款贷方余额表示什么
  • 收到政府补助需要缴纳企业所得税吗
  • 员工离职补偿需要计提吗
  • 房地产企业回迁房增值税
  • 买一赠一销售收入计算案例
  • 控股股权转让
  • 机票退票账务处理
  • 小规模纳税人购买原材料会计分录
  • 银行汇票使用流程举例
  • 公司怎么样才能给员工交社保
  • 金税盘的年费怎么做抵扣帐
  • 未达起征点怎么写摘要
  • 金税盘开的发票显示未报送怎么办
  • 办公室房租计入什么科目
  • 非税收入的发票能抵扣吗
  • 增值税一般项目是指什么
  • 小微企业 2021
  • 1697509200
  • 设备安装合同预付款比例
  • 采购不签合同
  • 如何把私人账户冻结
  • 土地价款扣除会计分录
  • 厂区绿化工程计入什么科目
  • 安全生产专用设备目录
  • PHP:realpath_cache_get()的用法_Filesystem函数
  • wordpress使用
  • php单例模式应用场景
  • 废旧物资发票抵扣
  • Yii2超好用的日期和时间组件(值得收藏)
  • iis安装php环境
  • php中自定义常量的函数是
  • qt+opencv教程
  • 帝国cms安装教程
  • mysql中regexp_replace函数的使用
  • 收押金退押金会计分录
  • 什么是汇算清缴申报表
  • 保险赔偿收入会计分录
  • 企业有什么项目
  • mysql行锁的作用
  • 赠品怎么做
  • 异地如何申报纳税
  • 确认收入的时点包括
  • 个税填在资产负债表哪个地方
  • 企业所得税研发费用加计扣除例题
  • 发票入账需要哪些附件的文件
  • 企业所得税汇算清缴操作流程
  • 领用库存商品用于生产产品
  • 应交税金及附加怎么计算
  • 公司注册资金抽走违法吗
  • 充卡送礼品送些什么好
  • 国有资产如何保值
  • 不同银行的存款
  • 现金折扣和商业折扣怎么确定收入
  • 计提应付票据利息10000的会计分录
  • 货物破损怎么写会计分录
  • 商贸公司会计成本核算方法
  • 会计的职务是什么意思
  • mysql5.6源码安装
  • win10小娜语音激活
  • win2003注册表空间不足
  • Linux httpd(apache)启动失败 解决办法
  • iis搭建php环境
  • win8.1system磁盘占用率高
  • window10如何校色
  • windows8如何分盘
  • html模板 js
  • JavaScript打开WPS
  • framelayout布局
  • node.js windows
  • Android---41---Service简介
  • javascript函数的定义
  • python如何批量造数据
  • 云税票管家是什么软件
  • 国税系统三方协议
  • 北京市地税局领导
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设