vite+vue3展示文件夹内的所有组件

news/2025/1/10 16:25:18/文章来源:https://www.cnblogs.com/chinasoft/p/18245859

https://www.cnblogs.com/y-shmily/p/16546743.html

 

在组件目录下新建index.js

复制代码
import { markRaw } from "vue";
const filesNameList = [];
const files = import.meta.glob("./*.vue");for (const key in files) {const fileName = key.replace(/(\.\/|\.vue)/g, "");filesNameList.push(fileName);
}
// 导出当前目录下的所有.vue的文件
export default markRaw(filesNameList);
复制代码

展示所有组件 index.vue

复制代码
<template><div class="drag-box"><div class="head"><h3>组件列表</h3></div><div class="compList"><!-- 渲染所有组件 --><el-cardclass="items"shadow="hover"v-for="element in componentList":key="element.FileName"><div class="title"><b>组件名: </b>{{ element.FileName }}</div><div class="compMian"><component :is="element.component"></component></div></el-card></div></div>
</template><script setup>
import { ref, defineAsyncComponent, markRaw } from "vue";
// 引入modules目录下所有的模板名称数组
import allComps from "./modules";
const componentList = ref([]);
allComps.map((v) => {let item = {FileName: "",component: null,};item.FileName = v;// 导入组件item.component = markRaw(defineAsyncComponent(() => import(`./modules/${v}.vue`)));// 组件列表追加组件信息componentList.value.push(item);
});
</script><style lang="less" scoped>
.drag-box .items {width: 100%;margin: 20px 0;border-bottom: solid 1px #999;// background-color: #eee;.title {font-size: 18px;line-height: 1.5;margin-bottom: 25px;border-bottom: solid 1px #eee;b {font-size: 22px;}}.compMian {background-color: #fff;}
}
</style>
复制代码

目录结构

import { markRaw } from "vue";
const filesNameList = [];
const files = import.meta.glob("./*.vue");

for (const key in files) {
  const fileName = key.replace(/(\.\/|\.vue)/g, "");
  filesNameList.push(fileName);
}
// 导出当前目录下的所有.vue的文件
export default markRaw(filesNameList);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/724279.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

龙哥量化:通达信今买明卖2024选股指标公式源码

如果您需要代写公式, 请联系我。 龙哥QQ:591438821 龙哥微信:Long622889 XYZ_1:=MAX(MAX(HIGH-LOW,Abs(REF(CLOSE,1)-HIGH)),ABS(REF(CLOSE,1)-LOW));XYZ_2:=(HIGH+LOW)/2+MA(XYZ_1,2);XYZ_3:=(HIGH+LOW)/2-MA(XYZ_1,2);XYZ_4:=REF(XYZ_2,BArslAST(XYZ_2<=REF(XYZ_2,1)))…

如何使您的IT资产审计变得轻而易举?

无论您在审核准备方面处于哪个阶段,强大的资产管理策略都至关重要。 现在,不可否认的是最初的障碍——精确追踪每一台设备、软件许可证和外围设备可能会让人感到不知所措。然而,好消息是有简化流程可以帮助您将资产管理从一项令人望而却步的任务转变为高效的实践。 当您发…

keil 烧入程序 过慢 解决方法

1.打开魔术笔 2.点击 切换debug 3.点击 settings4. 把MHZ改成4,点击确定就OK了

CSRF漏洞复现及测试工具讲解

一、Python编写一个存在CSRF漏洞① 编写html网页<!DOCTYPE html> <html> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>转账</title&g…

redis自学(47)批处理优化

大量数据的导入的方式Redis提供的批处理方案M操作比Pipeline快,因为M操作是内部操作,原子操作,而Pipeline不是。集群下的批处理 如MSET或Pipeline这样的批处理需要在一次请求中携带多条命令,而此时如果redis是一个集群,那批处理命令的多个key必须落在一个插槽中,否则就会…

妙用OSGraph:发掘GitHub知识图谱上的开源故事

OSGraph (Open Source Graph) 是一个开源图谱关系洞察工具,基于GitHub开源数据全域图谱,实现开发者行为、项目社区生态的分析洞察。可以为开发者、项目Owner、开源布道师、社区运营等提供简洁直观的开源数据视图,帮助你和你的项目制作专属的开源名片、寻求契合的开发伙伴、挖…

云消息队列 ApsaraMQ 成本治理实践(文末附好礼)

本文将探讨云消息队列 ApsaraMQ 在成本治理方面的实践经验,同时介绍在 Serverless 版本中的架构优化和新增能力。希望能够为企业或个人提供成本控制参考,同时帮助大家更好地理解和使用云消息队列 ApsaraMQ,以实现成本效益最大化。作者:家泽、稚柳 前言: 在 AI 原生应用架构…

DNF单机源码架设教程|无需服务器|虚拟机一键搭建

一. 搭建所需要的文件 获取地址:https://githubs.xyz/boot/?app=15 二.搭建步骤 只需一台windows系统,首先需要安装vm虚拟机 目录在vm虚拟机下面 安装完成打开 需要输入激活序列号, 在 VM序列号.txt 里面,16.0的 左上角 文件 打开 选择: 服务端-> DNF Server 7.9 x64.…

elasticsearch之ik分词器和自定义词库实现

ElasticSearch分词器 所谓的分词就是通过tokenizer(分词器)将一个字符串拆分为多个独立的tokens(词元-独立的单词),然后输出为tokens流的过程。 例如"my name is HanMeiMei"这样一个字符串就会被默认的分词器拆分为[my,name,is HanMeiMei].ElasticSearch中提供了很多…

Oracle报错:“Error in invoking target ‘agent nmhs’ of makefile...”

Oracle报错:“Error in invoking target ‘agent nmhs’ of makefile...”前言:Oracle在安装过程中的报错一定要重视,这决定你后续是否能完成安装以及是否能使用。我这边会陆续汇总一些报错现象以及解决方案共享。##Install Product 86%报错信息 :“Error in invoking targ…

VSCode_运行unittest用例:提示文件-test未运行,控制台提示缺少env

如下图:解决方法: a.vscode安装插件:Python Extension Pack。 b.安装成功,重新打开VS Code窗口

从零开始写 Docker(十八)---容器网络实现(下):为容器插上”网线“

本文为从零开始写 Docker 系列第十八篇,利用 linux 下的 Veth、Bridge、iptables 等等相关技术,构建容器网络模型,为容器插上”网线“。完整代码见:https://github.com/lixd/mydocker 欢迎 Star推荐阅读以下文章对 docker 基本实现有一个大致认识:核心原理:深入理解 Dock…