一个脚本实现批量修改文件,减少重复工作

假设有这么一个场景,我们接收一个 React 的旧项目,该项目使用的是 js 开发的,按照正常来说,该文件的结尾应该是使用 jsx 来进行开发的,但是项目中使用的是 js 文件结尾来进行编写。

我们想要更改一下所有的文件,那么我们有什么办法去修改到这些文件,又能实现节省时间呢,通过这篇文章我们将来学习一下怎么通过这个脚本来实现这个功能。

实现

具体代码实现如下所示:

js 复制代码
const fs = require("fs");
const path = require("path");

const srcDirectory = "./src";

// 正则表达式匹配JSX标签
const jsxRegex = /<\w+(\s+[^>]*)*>/;

// 递归地遍历文件夹
function walkDir(dir, callback) {
  fs.readdirSync(dir).forEach((f) => {
    let dirPath = path.join(dir, f);
    let isDirectory = fs.statSync(dirPath).isDirectory();
    isDirectory ? walkDir(dirPath, callback) : callback(dirPath);
  });
}

// 检查文件内容是否包含JSX代码
function checkAndRename(filePath) {
  const content = fs.readFileSync(filePath, "utf8");
  if (jsxRegex.test(content)) {
    const newPath = filePath.replace(/\.js$/, ".jsx");
    fs.renameSync(filePath, newPath);
    console.log(`Renamed: ${filePath} -> ${newPath}`);
  }
}

// 开始遍历src目录
walkDir(srcDirectory, (filePath) => {
  if (path.extname(filePath) === ".js") {
    checkAndRename(filePath);
  }
});

这段代码的核心是一个递归函数,遍历所有文件夹和文件。对于每个.js 文件,脚本读取其内容并使用正则表达式检测是否存在 JSX 模式。如果检测到 JSX,脚本就会将文件重命名为.jsx。

为什么要检测他是否有写 jsx 代码,而不是是否有引入 React 的依赖包呢?答案是在 nextjs 中,你可以不导入 react 依赖包的情况下可以直接编写 jsx 代码,因为在项目中,src 目录下我们不仅要 jsx 代码,还包括了一些工具函数,这些函数是不需要 jsx 文件结尾的。

接下来我们看看该代码的运行结果,首先创建如下文件:

执行代码,最终结果如下图所示:

代码执行完成,只有 index.js 文件发送了变化,utils.js 并没有发生变化。

这个过程是自动的,可以在几秒钟内处理整个项目。

总结

自动化工具和脚本是现代软件开发的重要组成部分,能够显著提高开发效率和代码质量。通过使用简单但强大的脚本,如本文介绍的 JS 到 JSX 的转换器,开发团队可以更加专注于创造价值,而不是重复的、机械的任务。

相关推荐
张拭心1 小时前
Cursor 又偷偷更新,这个功能太实用:Visual Editor for Cursor Browser
前端·人工智能
I'm Jie1 小时前
深入了解 Vue 3 组件间通信机制
前端·javascript·vue.js
用户90443816324602 小时前
90%前端都踩过的JS内存黑洞:从《你不知道的JavaScript》解锁底层逻辑与避坑指南
前端·javascript·面试
CodeCraft Studio3 小时前
文档开发组件Aspose 25.12全新发布:多模块更新,继续强化文档、图像与演示处理能力
前端·.net·ppt·aspose·文档转换·word文档开发·文档开发api
PPPPickup3 小时前
easychat项目复盘---获取联系人列表,联系人详细,删除拉黑联系人
java·前端·javascript
老前端的功夫3 小时前
前端高可靠架构:医疗级Web应用的实时通信设计与实践
前端·javascript·vue.js·ubuntu·架构·前端框架
前端大卫4 小时前
【重磅福利】学生认证可免费领取 Gemini 3 Pro 一年
前端·人工智能
孜燃4 小时前
Flutter APP跳转Flutter APP 携带参数
前端·flutter
脾气有点小暴4 小时前
前端页面跳转的核心区别与实战指南
开发语言·前端·javascript
lxh01134 小时前
最长递增子序列
前端·数据结构·算法