当前位置: 首页 > news >正文

【Vue3】递归组件

1. 递归组件mock数据

App.vue

<template><div><Tree :data="data"></Tree></div>
</template><script setup lang="ts">
import { reactive } from 'vue';
import Tree from './components/Tree.vue';
interface Tree {name: string,checked: boolean,children?: Tree[]
}
const data = reactive<Tree[]>([{name: '1',checked: true,children: [{name: '1-1',checked: false}]},{name: '2',checked: true,},{name: '3',checked: false,children: [{name: '3-1',checked: false,children: [{name: '3-1-1',checked: false},{name: '3-1-2',checked: true},],}]},])
</script><style lang="scss" scoped></style>

2. 递归组件定义名称

子组件Tree.vue

<template><div class="tree" v-for="item in data"><input v-model="item.checked" type="checkbox"> <span>{{ item.name }}</span>// 1.模板自定义名称 直接使用文件名当做递归组件的名称 Tree<Tree v-if="item?.children?.length" :data="item?.children"></Tree></div>
</template><script setup lang="ts">
// import { ref,reactive } from 'vue';
interface Tree {name: string,checked: false,children?: Tree[]
}// // 3.模板自定义名称 利用defineOptions
// defineOptions({
//   name: 'nihao'
// })defineProps<{data?: Tree[]
}>()
</script><!-- // 2.模板自定义名称
<script lang="ts">
//可以将模板中的Tree改名为“nihao”
export default {name: "nihao"
}
</script> --><style lang="scss" scoped>
.tree {margin-left: 10px;
}
</style>

3. 递归组件处理事件

子组件Tree.vue

<template><div @click.stop="clickTap(item,$event)" class="tree" v-for="item in data"><input v-model="item.checked" type="checkbox"> <span>{{ item.name }}</span><Tree v-if="item?.children?.length" :data="item?.children"></Tree></div>
</template><script setup lang="ts">
// import { ref,reactive } from 'vue';
interface Tree {name: string,checked: false,children?: Tree[]
}defineProps<{data?: Tree[]
}>()const clickTap = (item:Tree,e) => {console.log(item, e.target);
}
</script><style lang="scss" scoped>
.tree {margin-left: 10px;
}
</style>

在这里插入图片描述

http://www.lryc.cn/news/101890.html

相关文章:

  • 【Python】数据分析+数据挖掘——探索Pandas中的索引与数据组织
  • matlab进阶:求解在约束条件下的多元目标函数最值(fmincon函数详解)
  • Kotlin知识点
  • 亚马逊云科技联合霞光社发布《2013~2023中国企业全球化发展报告》
  • 【解析excel】利用easyexcel解析excel
  • JQuery操作单选按钮Radio和复选框checkbox
  • 7.28 作业 QT
  • HTML <pre> 标签
  • 查询结果元数据-MetaData对象、数据库工具类的封装、通过反射实现数据查询的封装
  • 【Minio中间件】上传图片并Vue回显
  • Jmeter配置不同业务请求比例,应对综合场景压测
  • 数学分析:流形的线性代数回顾
  • 前端请求后端接口返回错误码
  • 【Java Web】Nacos 介绍和安装教程
  • web漏洞-java安全(41)
  • 用CSS和HTML写一个水果库存静态页面
  • 【回眸】备考PMP考点汇总 三(距离考试还有20天)
  • 新房的收房验房注意事项
  • ARM裸机-5
  • SpringCloud学习路线(11)——分布式搜索ElasticSeach场景使用
  • 负数补码表示
  • ChatGPT结合知识图谱构建医疗问答应用 (一) - 构建知识图谱
  • C++ 类和对象
  • c# 此程序集中已使用了资源标识符
  • WPF实战学习笔记30-登录、注册服务添加
  • GDAL C++ API 学习之路 OGRGeometry 圆弧类 OGRCircularString
  • 机器学习:异常检测
  • flask中的蓝图
  • Spring Cloud+Spring Boot+Mybatis+uniapp+前后端分离实现知识付费平台免费搭建
  • uniapp 瀑布流 (APP+H5+微信小程序)