iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >vue3.0之怎么写tsx语法
  • 714
分享到

vue3.0之怎么写tsx语法

2023-07-02 18:07:10 714人浏览 八月长安
摘要

这篇文章主要讲解了“vue3.0之怎么写tsx语法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3.0之怎么写tsx语法”吧!import { defineConf

这篇文章主要讲解了“vue3.0之怎么写tsx语法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue3.0之怎么写tsx语法”吧!

import { defineConfig } from 'vite'import vue from '@vitejs/plugin-vue'import vueJsx from '@vitejs/plugin-vue-jsx';// https://vitejs.dev/config/export default defineConfig({  plugins: [vue(),vueJsx()]})

02:tsconfig.JSON 配置文件

    "jsx": "preserve",    "jsxFactory": "h",    "jsxFragmentFactory": "Fragment",

经过上述的配置就可以使用 ts了

测试tsx 新建一个App.tsx页面

再App.vue文件之中引入使用

<template>  <!-- <Layout></Layout> -->  <renderDom /></template><script setup lang="ts">// import Layout from './layout/Layout.vue'import renderDom from './App.tsx'</script><style lang="sCSS">html,body,#app {  height: 100%;  width: 100%;  overflow: hidden;}</style>

tsx使用v-model指令 (App.tsx组件)

import { ref } from "vue"let test = ref<string>("")const renderDom = () => {  // 注意点:在tsx之中 不会自动读写 X.value  return (    <div>      <input type="text" v-model={test.value} />      <div>我是{test.value }</div>    </div>  )}export default renderDom

效果

vue3.0之怎么写tsx语法

使用v-show、与三目运算符

  • tsx是支持v-show指令

  • tsx不支持v-if、v-else指令,这时候需要使用到三目运算符了

import { ref } from "vue"let flag = ref<Boolean>(true)const renderDom = () => {  // 注意点:在tsx之中 不会自动读写 X.value  return (    <div>      <div v-show={flag}>我是true</div>      <div v-show={!flag}>我是flase</div>      <div>        {          flag ? <div>我是true</div> : <div>我是flase</div>        }      </div>    </div>  )}export default renderDom

效果

vue3.0之怎么写tsx语法

tsx之数组的遍历(map)

  • tsx是不支持 v-for指令的

  • 使用map的方式去遍历数组,然后map函数之中返回一个 div等标签渲染dom节点

import { Reactive, ref } from "vue"let arr = reactive<Number[]>([1,2,3])const renderDom = () => {  return (    <div>      <div>        {          arr.map((item,idx)=>{            return(              <div key={idx}>{ item }</div>            )           })        }      </div>    </div>  )}export default renderDom

效果

vue3.0之怎么写tsx语法

自定义属性 data-index

给当前标签自定义属性用于数据的传递

import { reactive, ref } from "vue"let arr = reactive<Number[]>([1,2,3])const renderDom = () => {  return (    <div>      <div>        {          arr.map((item,idx)=>{            return(              <div key={idx} data-index={idx}>{ item }</div>            )           })        }      </div>    </div>  )}export default renderDom

效果

vue3.0之怎么写tsx语法

tsx绑定事件

使用onClick定义事件

  • 不传递参数的时候,直接定义这个click事件即可

  • 若是传递参数的时候,需要使用bind来改变this的指向,并且不自觉调用函数,而是返回一个新的函数,可以传递参数,等待点击的时候触发事件

import { reactive, ref } from "vue"let arr = reactive<Number[]>([1,2,3])const renderDom = () => {  return (    <div>      <div>        {          arr.map((item,idx)=>{            return(              // <div key={idx} data-index={idx} onClick={TestClick}>{ item }</div> // 没有传参              // <div key={idx} data-index={idx} onClick={TestClick()}>{ item }</div> // 直接调用              <div key={idx} data-index={idx} onClick={TestClick.bind(this,item)}>{ item }</div>            )           })        }      </div>    </div>  )}const TestClick = (item)=>{  console.log("111",item);  }export default renderDom

tsx之 props父组件向子组件传递参数

App.vue 父

再vue之中,使用 v-bind的形式传递数据

<template>  <renderDom :title="title" /></template><script setup lang="ts">import { ref } from 'vue'import renderDom from './App.tsx'let title = ref<String>('我是测试的t')</script>

App.tsx 子

import { reactive, ref } from "vue"type Props = {  title : string}const renderDom = (props:Props) => {  return (    <div>      <div>我是title - { props.title }</div>    </div>  )}export default renderDom

效果

vue3.0之怎么写tsx语法

tsx之子组件 向父组件 传递数据

点击11 传递当前11数据

子组件 App.tsx

import { reactive, ref } from "vue"type Props = {  title : string}let arr = reactive<number[]>([11,22,33])// props是接受父组件传递来的值,ctx:为上下文对象const renderDom = (props:Props,ctx:any) => {  return (    <div>      <div>我是title - { props.title }</div>      <div>        {          arr.map((item,idx)=>{            return (              <div onClick={ itemClick.bind(this,ctx,item) }>{  item }</div>            )          })        }      </div>    </div>  )}// 点击事件const itemClick = (ctx:any,item:any)=>{  ctx.emit("on-click",item) // 使用ctx之中的emit发射事件,给父组件传递数据}export default renderDom

App.vue 父

<template>  <!-- <Layout></Layout> -->  <renderDom :title="title" @on-click="getData" /></template><script setup lang="ts">// import Layout from './layout/Layout.vue'import { ref } from 'vue'import renderDom from './App.tsx'let title = ref<String>('我是测试的t')// 接受子组件 自定义事件 传递来的数据const getData = (parmas) => {  console.log('getData', parmas)}</script>

感谢各位的阅读,以上就是“vue3.0之怎么写tsx语法”的内容了,经过本文的学习后,相信大家对vue3.0之怎么写tsx语法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: vue3.0之怎么写tsx语法

本文链接: https://www.lsjlt.com/news/343602.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue3.0之怎么写tsx语法
    这篇文章主要讲解了“vue3.0之怎么写tsx语法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue3.0之怎么写tsx语法”吧!import { defineConf...
    99+
    2023-07-02
  • vue3.0语法糖内的defineProps及defineEmits怎么用
    这篇文章主要介绍“vue3.0语法糖内的defineProps及defineEmits怎么用”,在日常操作中,相信很多人在vue3.0语法糖内的defineProps及defineEmits怎么用问题上存在疑惑,小编查阅了各式资料,整理出简...
    99+
    2023-06-30
  • LINQ查询语法怎么写
    这篇文章将为大家详细讲解有关LINQ查询语法怎么写,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。LINQ查询语法首先来看一个很简单的LINQ查询例子,查询一个int 数组中小于5的数字,并按照大小顺序排列...
    99+
    2023-06-17
  • mysql查询语法怎么写
    非常抱歉,由于您没有提供文章标题,我无法为您生成一篇高质量的文章。请您提供文章标题,我将尽快为您生成一篇优质的文章。...
    99+
    2024-05-22
  • JavaScript之怎么手写asyncAdd方法
    这篇文章主要介绍了JavaScript之怎么手写asyncAdd方法的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript之怎么手写asyncAdd方法文章都会有所...
    99+
    2024-04-02
  • CSS伪类的语法怎么写
    这篇文章主要介绍“CSS伪类的语法怎么写”,在日常操作中,相信很多人在CSS伪类的语法怎么写问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS伪类的语法怎么写”的疑惑有所帮...
    99+
    2024-04-02
  • css左边框语法怎么写
    这篇文章主要讲解了“css左边框语法怎么写”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css左边框语法怎么写”吧!css左边框语法是“border-left:值;”;“border-lef...
    99+
    2023-07-05
  • css清除浮动语法怎么写
    这篇文章给大家分享的是有关css清除浮动语法怎么写的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。清除浮动.clearfix:after{ content: '', h...
    99+
    2023-06-19
  • MySQL优化之怎么写出高质量sql语句
    这篇文章将为大家详细讲解有关MySQL优化之怎么写出高质量sql语句,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1. 查询SQL尽量不要使用全查 select *,而是 select + 具体...
    99+
    2023-06-15
  • css文本域语法格式怎么写
    这篇文章主要介绍“css文本域语法格式怎么写”,在日常操作中,相信很多人在css文本域语法格式怎么写问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”css文本域语法格式怎么写”...
    99+
    2024-04-02
  • word中拼写和语法怎么检查
    在Microsoft Word中,您可以使用拼写和语法检查功能来检查您的拼写和语法错误。要检查拼写和语法,请按照以下步骤操作:1. ...
    99+
    2023-09-17
    word
  • mysql中模糊查询语法怎么写
    这篇文章主要介绍了mysql中模糊查询语法怎么写,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。MySQL LIKE模糊查询我们知道在 MySQL...
    99+
    2024-04-02
  • c语言99乘法表代码怎么写
    以下是一个简单的C语言代码示例,用于打印出九九乘法表:```c#include int main() {int i, j;for(i...
    99+
    2023-08-09
    c语言
  • vscode写vue没有高亮语法怎么办
    本教程操作环境:windows7系统、vue3&&Visual Studio Code 1.74.0版,DELL G3电脑。vscode设置vue语法高亮显示一、在编辑器中安装Vetur插件1.1 、打开vs code编辑器...
    99+
    2023-05-14
    Vue VSCode
  • ES6基础语法之class类怎么用
    这篇文章主要介绍了ES6基础语法之class类怎么用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇ES6基础语法之class类怎么用文章都会有所收获,下面我们一起来看看吧。一、class基本语法JavaScri...
    99+
    2023-06-30
  • c语言helloworld怎么写
    在 c 语言中,"hello, world!" 程序用于输出文本"hello, world!",是编写 c 程序的基本步骤。具体步骤包括:创建源文件,扩展名为 ".c";编写代码,包含头...
    99+
    2024-04-05
    c语言
  • oracle怎么写sql语句
    编写 oracle sql 语句需要遵循以下步骤:1. 连接到数据库;2. 选择要检索的列;3. 指定条件(可选);4. 对结果进行排序(可选);5. 限制结果数量(可选);6. 使用聚...
    99+
    2024-04-19
    oracle sql语句 聚合函数
  • mysql怎么写sql语句
    mysql sql 语句是与 mysql 数据库交互的一种方式,可用于创建数据库、表、插入、更新和删除数据,以及检索和过滤数据。语法一般为:command [options] [targ...
    99+
    2024-04-14
    mysql sql语句
  • sql insert语句怎么写
    SQL INSERT语句用于向数据库表中插入新的行。下面是一般的INSERT语句的语法:```sqlINSERT INTO tabl...
    99+
    2023-08-24
    SQL
  • go语言怎么写or
    go语言写or的步骤:1、声明了两个布尔类型的变量“condition1”和“condition2”,分别赋值为“true”和“false”;2、使用if语句判断“condition1”和“condition2”是否至少有一个为真;3、执行...
    99+
    2023-07-10
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作