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

  • 苹果手机频繁断信号(苹果手机频繁断流)

    苹果手机频繁断信号(苹果手机频繁断流)

  • 指纹识别不了(手机膜指纹识别不了)

    指纹识别不了(手机膜指纹识别不了)

  • 手机qq空间留言板在哪里(手机qq空间留言怎么删除)

    手机qq空间留言板在哪里(手机qq空间留言怎么删除)

  • iphone7屏幕短排线断了(iphone7屏幕排线图解)

    iphone7屏幕短排线断了(iphone7屏幕排线图解)

  • 网站为什么有红色的(网址有红线)

    网站为什么有红色的(网址有红线)

  • 苹果x微信闪退是什么原因(苹果x微信闪退打不开)

    苹果x微信闪退是什么原因(苹果x微信闪退打不开)

  • 不用ps怎么改照片大小(不用ps怎么改照片像素大小)

    不用ps怎么改照片大小(不用ps怎么改照片像素大小)

  • 华为stf_al00是啥型号(华为stf al00)

    华为stf_al00是啥型号(华为stf al00)

  • 转转卖出去钱多久到账(转转卖出后多久能收到钱)

    转转卖出去钱多久到账(转转卖出后多久能收到钱)

  • 抖音取消点赞会降低播放量吗(抖音取消点赞会怎样)

    抖音取消点赞会降低播放量吗(抖音取消点赞会怎样)

  • 智能辅助在手机哪儿(智能辅助在手机哪里打开)

    智能辅助在手机哪儿(智能辅助在手机哪里打开)

  • 链信的实名认证有风险吗(链信实名注册的危害)

    链信的实名认证有风险吗(链信实名注册的危害)

  • iphone已停用连接itunes恢复后数据还在吗(iphone已停用连接it u n e s)

    iphone已停用连接itunes恢复后数据还在吗(iphone已停用连接it u n e s)

  • 抖音私信能撤回嘛(抖音自动私信)

    抖音私信能撤回嘛(抖音自动私信)

  • 如何提取目录wps(如何提取目录放在旁边)

    如何提取目录wps(如何提取目录放在旁边)

  • 手机组装屏和原装屏的区别(手机组装屏和原装屏排线插口一样吗)

    手机组装屏和原装屏的区别(手机组装屏和原装屏排线插口一样吗)

  • 手机广角镜头怎么用(手机广角镜头怎么安装)

    手机广角镜头怎么用(手机广角镜头怎么安装)

  • 咸鱼退款卖家不处理怎么办(咸鱼退款卖家不同意可以退款吗?)

    咸鱼退款卖家不处理怎么办(咸鱼退款卖家不同意可以退款吗?)

  • 微星b450m如何开启Vt(微星b450vt怎么开启)

    微星b450m如何开启Vt(微星b450vt怎么开启)

  • 闪电盒子的红包口令是什么(闪电盒子红包版)

    闪电盒子的红包口令是什么(闪电盒子红包版)

  • 文字效果在哪设置(文字效果如何设置)

    文字效果在哪设置(文字效果如何设置)

  • 小米8网络卡怎么解决(小米八网络卡怎么解决)

    小米8网络卡怎么解决(小米八网络卡怎么解决)

  • 开放系统互联参考模型(开放系统互联参考模型采用了什么结构的构造技术)

    开放系统互联参考模型(开放系统互联参考模型采用了什么结构的构造技术)

  • hpsysdrv.exe是什么进程?hpsysdrv.exe是病毒吗?(hpdskflt.sys)

    hpsysdrv.exe是什么进程?hpsysdrv.exe是病毒吗?(hpdskflt.sys)

  • 【OpenCV-Python】:查找物体轮廓+计算轮廓面积、长度、重心(python的opencv)

    【OpenCV-Python】:查找物体轮廓+计算轮廓面积、长度、重心(python的opencv)

  • 消费税基本特点?
  • 个体工商户所得税核定征收2023
  • 增值税税率变化时间节点
  • 季度末收取房屋的会计处理
  • 出口货物退免税管理办法
  • 个税申报怎样作废
  • 生产车间领用低值易耗品
  • 未经过他人同意贷款怎么处理
  • 财政拨付的研发费用
  • 购入固定资产如何摊销
  • 收到客户定金账务怎么做
  • 股东分红利息
  • 电费做其他业务收入的账务处理怎么做?
  • 进项发票失控账务处理
  • 非公司汽车加油怎么开票
  • 预付款对应的会计科目
  • 核销的方式
  • 申报状态显示申报失败
  • 商业保险税前扣除限额
  • 七月一号出台的什么政策
  • 劳务费个人还需要交税吗
  • 分公司固定资产转入总公司的分录怎么做?
  • 收到押金入什么会计科目
  • 哪些税计入原材料费用
  • 转让投资性房地产收到售价款
  • 全员劳动生产率怎么计算出来的
  • 电脑每次开机都要选择系统怎么办
  • 以前年度应付账款做到制造费用如何改账
  • 进项发票失控怎么办
  • linux模块的概念
  • dsm是什么文件
  • 企业接受现金捐赠要交税吗
  • 直接材料成本差异账户在平时登记贷方登记
  • php评论盖楼
  • php上传多文件
  • kicad视频教程 百度网盘
  • 工会账户必须是专用账户吗
  • 发票开具使用要求
  • 装饰工程公司施工一般包括哪些内容?
  • 现金劳务收入会计分录
  • 人力资源投资收益
  • 兼职人员的工资怎么做账
  • 公司借款方式
  • 本年度的进项可以结转到下一年度吗
  • 租房合同 陷阱
  • 递延收益的摊销时点
  • 计提职工薪酬是什么意思
  • 再保险责任的承担
  • 收到所得税退税怎么做账务处理
  • 行政事业单位零星维修相关规定
  • 盘亏机器设备
  • 其他应收款与其他应付款对冲分录
  • 结转成本按照销售收入来结转,税要怎么算
  • 预算收入包括增值税吗
  • 未认证的发票不入账有什么影响
  • 出口视同内销如何申报?
  • 收据能作为抵减成本吗
  • 会计总账怎么做账
  • MySQL主从同步原理介绍
  • 利用pt-heartbeat监控MySQL的复制延迟详解
  • mysql 数据库
  • mysql索引作用的简单理解
  • mac快速操作在哪
  • macos使用方法
  • CentOS安装scp命令详解
  • xshell使用ssh命令远程连接linux
  • centos 删除恢复
  • MSupdate.exe - MSupdate是什么进程 有什么用
  • 驱动人生公司怎么样
  • w7升级w8.1
  • win7能装coreldraw2020吗
  • win 7笔记本连接投影仪
  • addObserver和postNotification函数传递函数的区别
  • jquery移除
  • 使用jquery插件的好处
  • 游戏开发unity3d
  • 深入理解中国式现代化
  • 利用python绘图
  • 国家税务局湖南省电子税务局app下载
  • 一般纳税人开具的增值税普通发票和专用发票的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设