记一次实际项目中,node应用,下划线命名方式改为驼峰命名当时

在项目后期,面对大量采用下划线命名的文件,为了统一为驼峰命名,作者利用Node.js编写了代码,实现了高效批量转换,避免了手动修改可能导致的遗漏和时间消耗。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

做到项目后期,整个项目相当庞大,突然leader让把之前的 _命名方式改为 驼峰命名方式,一个一个的改的话,估计得一两周,还不能保证能都改完了。

于是想到了node来做改一下,代码如下:

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

readDirList(__dirname)

/*

* params {string} 目录文件下得所有文件和文件夹

*/

function readDirList(currentDir) {
    fs.readdir(currentDir,(err,files) => {
        for(file of files) {
            if(file == 'upper.js') {
                console.log('upper.js 不做处理')
            }else {
                if(file.indexOf('.')!=-1) { // 文件
                    if(file.indexOf('.vue')!=-1 || file.indexOf('.js')!=-1 || file.indexOf('.css')!=-1) { 
                       // 只改动.vue .js .css文件
                        writeFileToUpper(path.join(currentDir,file))
                    }else if(file.indexOf('.jpg') != -1 || file.indexOf('.png') != -1) {
                        filenameToUpper(currentDir, file)
                    }else {
                        // console.log('不作处理123'+file+'为什么')
                    }
                }else { // 文件夹
                    readDirList(path.join(currentDir,file))
                }
            }
        }
    })
}

/*

* params {string} 文件名

*/

function writeFileToUpper(filename) {
    fs.readFile(filename,'utf8',function(err, data) {
    let str = data
    while (str.indexOf('_') != -1) {
        let index = str.indexOf('_')
        str = str.slice(0,index) + str.slice(index+1,index+2).toLocaleUpperCase() + str.slice(index+2,)
    }
    fs.writeFile(filename,str,'utf8',(err) => {
    })
    })
}

/*

* 文件中图片 _ 变 驼峰

*/

function filenameToUpper (currentDir, filename) {
    let newFile = filename
    while (newFile.indexOf('_') != -1) {
        let index = newFile.indexOf('_')
      newFile = newFile.slice(0,index) + newFile.slice(index+1,index+2).toLocaleUpperCase() + newFile.slice(index+2,)
    }
    console.log(newFile, filename)
    fs.rename(path.join(currentDir,filename), path.join(currentDir,newFile), function(err) {
        if(err) {
            console.log(err)
        }else {
            console.log("图片替换成功")
        }
    })
}

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值