如何在Vue3中书写TSX

免费教程   2024年01月19日 15:21  

今天小编给大家分享的是如何在Vue3中书写TSX,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。

在vue2的时候就已经可以使用 jsx 语法,但是不是很友好,写起来是一件很痛苦的事情,所以你很少见到有人会在vue2中书写 jsx 语法,官方也不建议我们在vue2中进行书写 jsx 的代码风格:

但随着vue3版本的到来,对typescript的支持度越来越高,tsx语法也被大部分人越来越接收,所以很多项目都是搭配 Vue3 + TS 进行的,所以在vue3项目中懂得如何书写 风格的代码,对于代码扩展学习还是有必要的。接下来将详细介绍使用vite构建工具创建vue3项目的tsx具体使用:

插件安装与文件配置

终端执行如下命令进行相关插件的安装:

npminstall@vitejs/plugin-vue-jsx-D

安装完成之后需要对配置文件 vite.config.ts 进行相关配置,如下:

import{defineConfig}from'vite'importvuefrom'@vitejs/plugin-vue'importvueJsxfrom'@vitejs/plugin-vue-jsx'//https://vitejs.dev/config/exportdefaultdefineConfig({plugins:[vue(),vueJsx()],})tsx语法格式

在vue3中创建后缀名为 .tsx 后缀的文件,其使用方法有如下三种方式,如果是学过React的朋友不难发现,vue3的一些语法是越来越像react了,这样的好处也是降低了学习react的成本。

返回渲染函数:

使用optionsApi方法:

使用setup函数模式:

tsx语法注意事项

在vue3中书写tsx语法的时候,有一些vue自带指令是不能使用的,如下进行简单的介绍:

map代替v-for:在tsx语法中不能使用v-for指令,需要使用map,这一点与react极其相似

import{defineComponent,ref}from"vue";exportdefaultdefineComponent({setup(){constflag=ref(false)constdata=[{name:'1'},{name:'2'},{name:'3'},{name:'4'},]return()=>(<><divv-if={flag.value}>张三</div>{data.map((item)=>{return<div>{item.name}</div>})}</>)}})

{}代替v-bind:在tsx语法中通过{}来代替v-bind的效果,如下:

props与emit的使用: 使用tsx语法时也可以使用vue的props与emit语法,如下:

在子组件定义props数据,如下:

import{defineComponent,ref}from"vue";interfaceProps{name?:string}exportdefaultdefineComponent({props:{name:String},emits:['on-click'],setup(props:Props){constflag=ref(false)constdata=[{name:'1'},{name:'2'},{name:'3'},{name:'4'},]return()=>(<><div>props:{props?.name}</div><hr/><divv-if={flag.value}>张三</div>{data.map((item)=>{return<divclass={item.name}>{item.name}</div>})}</>)}})import{defineComponent,ref}from"vue";interfaceProps{name?:string}exportdefaultdefineComponent({props:{name:String},emits:['on-click'],setup(props:Props){constflag=ref(false)constdata=[{name:'1'},{name:'2'},{name:'3'},{name:'4'},]return()=>(<><div>props:{props?.name}</div><hr/><divv-if={flag.value}>张三</div>{data.map((item)=>{return<divclass={item.name}>{item.name}</div>})}</>)}})

在父组件通过props传递数据,进行父向子传值,如下:

<template><testname="张三"/></template>

接下来开始使用emit函数实现子向父传值:

v-model的使用:

关于如何在Vue3中书写TSX就分享到这里了,希望以上内容可以对大家有一定的参考价值,可以学以致用。如果喜欢本篇文章,不妨把它分享出去让更多的人看到。

域名注册
购买VPS主机

您或许对下面这些文章有兴趣:                    本月吐槽辛苦排行榜

看贴要回贴有N种理由!看帖不回贴的后果你懂得的!


评论内容 (*必填):
(Ctrl + Enter提交)   

部落快速搜索栏

各类专题梳理

网站导航栏

X
返回顶部