百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分析 > 正文

vue3.2 vite获取目录下.vue、.tsx全部文件的方法

liebian365 2024-11-09 13:43 28 浏览 0 评论

方法一

可以使用 Node.js 的 fs 模块来读取目录下的文件,然后筛选出需要的文件。

下面是一个示例代码(需要安装 fs 模块和 path 模块):

const fs = require('fs');
const path = require('path');

const walk = (dir, exts) => {
  const files = fs.readdirSync(dir);
  const result = [];

  for (const file of files) {
    const filepath = path.join(dir, file);
    const stat = fs.statSync(filepath);

    if (stat.isDirectory()) {
      // 如果是目录,则递归处理子目录
      result.push(...walk(filepath, exts));
    } else if (exts.includes(path.extname(filepath))) {
      // 如果是指定的扩展名,则加入结果数组
      result.push(filepath);
    }
  }

  return result;
};

// 读取当前目录下的所有 .vue 和 .tsx 文件
const files = walk(process.cwd(), ['.vue', '.tsx']);

console.log(files);

这个代码会读取当前目录下的所有文件,包括子目录中的文件,然后筛选出扩展名为 .vue.tsx 的文件,并返回一个包含这些文件路径的数组。你可以根据需要调整 walk 函数的参数,比如可以把目录路径改为一个变量,或者把要匹配的扩展名改为函数参数等。

方法二

import.meta.glob 是 Vue3.x 中新增的模块导入语法,可以实现动态导入模块。

下面是一个示例代码(需要安装 @vue/compiler-sfc 模块):

import { defineAsyncComponent } from 'vue';
import { compileTemplate } from '@vue/compiler-sfc';

// 扫描指定目录下的所有 .vue 和 .tsx 文件
const modules = import.meta.globEager('./*.+(vue|tsx)');

// 将所有组件异步化
for (const path in modules) {
  const component = modules[path].default;
  if (component.__esModule) {
    // 如果是 ES Module,默认导出的是一个 Object,需要取出 default 属性
    component.default = defineAsyncComponent(() => {
      // 动态编译模板
      const { template } = compileTemplate({
        source: component.template,
        filename: path,
        compilerOptions: { mode: 'module' },
      });
      // 返回异步组件
      return Promise.resolve({
        ...component,
        template,
      });
    });
  } else {
    // 如果是 CommonJS Module,直接对 module.exports 包装成异步组件
    modules[path].default = defineAsyncComponent(() =>
      Promise.resolve({
        ...component,
        template: component.template.default,
      })
    );
  }
}

// 输出所有组件
console.log(modules);

这个代码会扫描当前目录下的所有 .vue.tsx 文件,然后通过 import.meta.globEager 动态导入它们并转换成异步组件,最后输出一个包含所有组件的对象。其中,对于 ES Module 和 CommonJS Module 分别进行了处理。

对于 ES Module,需要对模板进行动态编译,然后返回一个包含组件选项和模板的对象。

对于 CommonJS Module,由于模板是以 module.exports = {} 的形式导出的,需要额外取出模板对象中的 default 属性。

需要注意的是,import.meta.globEager 是一个同步操作,会在代码执行时立即加载所有符合条件的文件。如果文件太多或者太大,可能会导致性能问题。如果需要异步加载模块,可以使用 import.meta.glob 方法。

相关推荐

go语言也可以做gui,go-fltk让你做出c++级别的桌面应用

大家都知道go语言生态并没有什么好的gui开发框架,“能用”的一个手就能数的清,好用的就更是少之又少。今天为大家推荐一个go的gui库go-fltk。它是通过cgo调用了c++的fltk库,性能非常高...

旧电脑的首选系统:TinyCore!体积小+精简+速度极快,你敢安装吗

这几天老毛桃整理了几个微型Linux发行版,准备分享给大家。要知道可供我们日常使用的Linux发行版有很多,但其中的一些发行版经常会被大家忽视。其实这些微型Linux发行版是一种非常强大的创新:在一台...

codeblocks和VS2019下的fltk使用中文

在fltk中用中文有点问题。英文是这样。中文就成这个样子了。我查了查资料,说用UTF-8编码就行了。edit->Fileencoding->UTF-8然后保存文件。看下下边的编码指示确...

FLTK(Fast Light Toolkit)一个轻量级的跨平台Python GUI库

FLTK(FastLightToolkit)是一个轻量级的跨平台GUI库,特别适用于开发需要快速、高效且简单界面的应用程序。本文将介绍Python中的FLTK库,包括其特性、应用场景以及如何通过代...

中科院开源 RISC-V 处理器“香山”流片,已成功运行 Linux

IT之家1月29日消息,去年6月份,中科院大学教授、中科院计算所研究员包云岗,发布了开源高性能RISC-V处理器核心——香山。近日,包云岗在社交平台晒出图片,香山芯片已流片,回片后...

Linux 5.13内核有望合并对苹果M1处理器支持的初步代码

预计Linux5.13将初步支持苹果SiliconM1处理器,不过完整的支持工作可能还需要几年时间才能完全完成。虽然Linux已经可以在苹果SiliconM1上运行,但这需要通过一系列的补丁才能...

Ubuntu系统下COM口测试教程(ubuntu port)

1、在待测试的板上下载minicom,下载minicom有两种方法:方法一:在Ubuntu软件中心里面搜索下载方法二:按“Ctrl+Alt+T”打开终端,打开终端后输入“sudosu”回车;在下...

湖北嵌入式软件工程师培训怎么选,让自己脱颖而出

很多年轻人毕业即失业、面试总是不如意、薪酬不满意、在家躺平。“就业难”该如何应对,参加培训是否能改变自己的职业走向,在湖北,有哪些嵌入式软件工程师培训怎么选值得推荐?粤嵌科技在嵌入式培训领域有十几年经...

新阁上位机开发---10年工程师的Modbus总结

前言我算了一下,今年是我跟Modbus相识的第10年,从最开始的简单应用到协议了解,从协议开发到协议讲解,这个陪伴了10年的协议,它一直没变,变的只是我对它的理解和认识。我一直认为Modbus协议的存...

创建你的第一个可运行的嵌入式Linux系统-5

@ZHangZMo在MicrochipBuildroot中配置QT5选择Graphic配置文件增加QT5的配置修改根文件系统支持QT5修改output/target/etc/profile配置文件...

如何在Linux下给zigbee CC2530实现上位机

0、前言网友提问如下:粉丝提问项目框架汇总下这个网友的问题,其实就是实现一个网关程序,内容分为几块:下位机,通过串口与上位机相连;下位机要能够接收上位机下发的命令,并解析这些命令;下位机能够根据这些命...

Python实现串口助手 - 03串口功能实现

 串口调试助手是最核心的当然是串口数据收发与显示的功能,pzh-py-com借助的是pySerial库实现串口收发功能,今天痞子衡为大家介绍pySerial是如何在pzh-py-com发挥功能的。一、...

为什么选择UART(串口)作为调试接口,而不是I2C、SPI等其他接口

UART(通用异步收发传输器)通常被选作调试接口有以下几个原因:简单性:协议简单:UART的协议非常简单,只需设置波特率、数据位、停止位和校验位就可以进行通信。相比之下,I2C和SPI需要处理更多的通...

同一个类,不同代码,Qt 串口类QSerialPort 与各种外设通讯处理

串口通讯在各种外设通讯中是常见接口,因为各种嵌入式CPU中串口标配,工业控制中如果不够还通过各种串口芯片进行扩展。比如spi接口的W25Q128FV.对于软件而言,因为驱动接口固定,软件也相对好写,因...

嵌入式linux为什么可以通过PC上的串口去执行命令?

1、uboot(负责初始化基本硬bai件,如串口,网卡,usb口等,然du后引导系统zhi运行)2、linux系统(真正的操作系统)3、你的应用程序(基于操作系统的软件应用)当你开发板上电时,u...

取消回复欢迎 发表评论: