[译]如何更有效的获取文件扩展名

问:如何获取文件扩展名?

var file1 = "50.xsl";
var file2 = "30.doc";
getFileExtension(file1); //xsl
getFileExtension(file2); //doc

function getFileExtension(filename) {
  /*TODO*/
}

方案一:正则表达式

function getFileExtension1(filename) {
    return (/[.]/.exec(filename)) ? /[^.]+$/.exec(filename)[0] : undefined;
}

方案二:使用Stringsplit方法

function getFileExtension2(filename) {
    return filename.split('.').pop();
}

上述两种方案无法覆盖一些极端情况,下面这个更健壮

方案三:使用StringslicelastIndexOf方法

function getFileExtension3(filename) {
    return filename.slice((filename.lastIndexOf('.') - 1 >>> 0) + 2);
}

console.log(getFileExtension3(''));                            // ''
console.log(getFileExtension3('filename'));                    // ''
console.log(getFileExtension3('filename.txt'));                // 'txt'   
console.log(getFileExtension3('.hiddenfile'));                 // ''
console.log(getFileExtension3('filename.with.many.dots.ext')); // 'ext'

这货怎么工作的?

  • String.lastIndexOf返回指定值的最后出现位置(本例里是:.)。如果返回-1,表示没找到该指定值

  • 当参数是filename.hiddenfile时,lastIndexOf的返回值分别是-10。然后无符号移位操作符-2转成了4294967294-1转成了4294967295,这个小技巧保证了极端状况下取值也不会异常

  • 然后String.prototype.slice就以上面的计算结果作为起始下标从原始字符串中提取出了正确的文件扩展名。如果上一步骤计算出的起始下标大于原始字符串长度,则返回''

比较

方案参数结果
正则表达式''undefined
'filename'undefined
'filename.txt''txt'
'.hiddenfile''hiddenfile'
'filename.with.many.dots.ext''ext'
Stringsplit ''''
'filename''filename'
'filename.txt''txt'
'.hiddenfile''hiddenfile'
'filename.with.many.dots.ext''ext'
StringslicelastIndexOf ''''
'filename'''
'filename.txt''txt'
'.hiddenfile'''
'filename.with.many.dots.ext''ext'

在线演示和性能

上述代码的线上实例
上述三个方案的性能测试

源码

JavaScript里如果获取文件扩展名

原文地址:How to get the file extension more efficiently

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值