使用js正则验证文件夹名是否符合规范

背景:

git提交代码时需要验证新增的文件名称是否复合规范。具体规范如下:

全部采用小写方式, 以中划线分隔,用 kebab-case方式 (小写、短横线连接方式) 正例: scripts / styles / components / images / utils / layouts / demo-styles / demo-scripts / img / doc 反例: script / style / demo_scripts / demoStyles / imgs / docs 【特殊】VUE 的项目中的 components 中的组件目录使用PascalCase格式(与驼峰法相似,单词大写开头)

 因此需要验证普通文件名是否符合中划线命名法(kebab-case)以及vvue的component下的文件夹 大驼峰命名法(CamelCase)

中划线命名法(kebab-case):

思路:

1、排除文件名有空格

2、排除大写字母

3、连接方式为其他方式比如:—— _ . 等(反推:命名中只能有小写字母和-)

4、排除关键字:script style imgs docs等等

结论:

1、限定以小写字母开头,并且中间只包括小写字母和-,以小写字母结尾:/^[a-z]{1}[a-z-]+[a-z]$/。

2、排除关键字。

// 关键字
const KEYWORDS = ["script","style","imgs","docs","break","else","new","var","case","finally","return","void","catch","for","switch","while","continue","function","this","with","default","if","throw","delete","in","try","do","instranceof","typeof","abstract","enum","int","short","boolean","export","interface","static","byte","extends","long","super","char","final","native","synchronized","class","float","package","throws","const","goto","private ","transient","debugger","implements","protected ","volatile","double","import","public"]

// 正则:限定以小写字母开头,并且中间只包括小写字母和-,以小写字母结尾
let reg = /^[a-z]{1}[a-z-]*?[a-z]$/;
// /^[a-z]{1}[a-z-0-9]*?[a-z0-9]$/  (这个是限定以小写字母开头,中间小写or数字,结尾数字。两位数的情况下中间可以省略)

// 要判断的文件名
let fileName = `xxxxx`

if(KEYWORDS.indexOf(fileName) > -1){
// 文件名是关键字
}else if( reg.test(fileName) ){ // 判断:限定以小写字母开头,并且中间只包括小写字母和-,以小写字母结尾
// 符合要求
}else{
// 不符合要求
}

大驼峰命名法(CamelCase):

// 正则:限定以大写字母开头,并且中间只包括大写or小写字母,以小写字母结尾
let reg = /^[A-Z]{1}[a-zA-Z]*?[a-z]$/;

// 关键字
const KEYWORDS = ["script","style","imgs","docs","break","else","new","var","case","finally","return","void","catch","for","switch","while","continue","function","this","with","default","if","throw","delete","in","try","do","instranceof","typeof","abstract","enum","int","short","boolean","export","interface","static","byte","extends","long","super","char","final","native","synchronized","class","float","package","throws","const","goto","private ","transient","debugger","implements","protected ","volatile","double","import","public"]

// 大写首字母字母的关键字
let up_keywords = KEYWORDS.map(item=>{
    return item.charAt(0).toUpperCase() + item.slice(1); 
})

// 要判断的文件名
let fileName = `xxxxx`

if(up_keywords.indexOf(fileName) > -1){
    // 文件名是关键字
}else if( reg.test(fileName) ){ // 判断:限定以小写字母开头,并且中间只包括小写字母和-,以小写字母结尾
    // 符合要求
}else{
    // 不符合要求
}

小驼峰命名法(lowerCamelCase):

// 正则:限定以大写字母开头,并且中间只包括大写or小写字母,以小写字母结尾
let reg = /^[a-z]{1}[a-zA-Z]*?[a-z]$/;
// 关键字
const KEYWORDS = ["script","style","imgs","docs","break","else","new","var","case","finally","return","void","catch","for","switch","while","continue","function","this","with","default","if","throw","delete","in","try","do","instranceof","typeof","abstract","enum","int","short","boolean","export","interface","static","byte","extends","long","super","char","final","native","synchronized","class","float","package","throws","const","goto","private ","transient","debugger","implements","protected ","volatile","double","import","public"]
// 要判断的文件名
let fileName = `xxxxx`

if(KEYWORDS .indexOf(fileName) > -1){
// 文件名是关键字
}else if( reg.test(fileName) ){ // 判断:限定以小写字母开头,并且中间只包括小写字母和-,以小写字母结尾
// 符合要求
}else{
// 不符合要求
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用JavaScript正则表达式验证英文时,我们可以根据一些常见的规则来编写正则表达式。 首先,英文通常由一个或多个英文字母组成,因此我们可以使用[a-zA-Z]来表示英文字母。接下来,我们需要考虑英文中可以包含的一些特殊字符,例如空格和连字符。空格可以使用\s来表示,连字符可以直接使用-表示。 然后,我们需要考虑英文的长度。根据实际需求,可以使用{min, max}来表示英文的最小和最大长度。例如,{2, 10}表示英文的长度应在2到10个字符之间。 最后,我们需要考虑英文是否可以包含其他字符,例如数字和标点符号。根据实际需求,可以使用[^]来表示英文中不应包含的字符。例如,[^0-9]表示英文中不应包含数字。 综上所述,我们可以使用以下正则表达式验证英文: ^[a-zA-Z\s-]{2,10}$ 它表示英文由2到10个英文字母、空格和连字符组成。 以下是一个示例,演示如何使用这个正则表达式验证英文: ``` const nameRegex = /^[a-zA-Z\s-]{2,10}$/; const name = "John Doe"; if (nameRegex.test(name)) { console.log("英文合法"); } else { console.log("英文不合法"); } ``` 注意,此处只是简单的示例,实际情况下可能需要根据具体需求进行调整和扩展。同时,对于不同的语言和文化背景,英文的规则可能会有所不同,需要根据实际情况来确定符合要求的正则表达式

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值