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; }
String
的split
方法function getFileExtension2(filename) { return filename.split('.').pop(); }
上述两种方案没法覆盖一些极端状况,下面这个更健壮javascript
String
的slice
,lastIndexOf
方法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'
这货怎么工做的?java
String.lastIndexOf返回指定值的最后出现位置(本例里是:.
)。若是返回-1
,表示没找到该指定值正则表达式
当参数是filename
,.hiddenfile
时,lastIndexOf
的返回值分别是-1
和0
。而后无符号移位操做符将-2
转成了4294967294
、-1
转成了4294967295
,这个小技巧保证了极端情况下取值也不会异常jsp
而后String.prototype.slice就以上面的计算结果做为起始下标从原始字符串中提取出了正确的文件扩展名。若是上一步骤计算出的起始下标大于原始字符串长度,则返回''
性能
方案 | 参数 | 结果 |
---|---|---|
正则表达式 | '' | undefined |
'filename' | undefined | |
'filename.txt' | 'txt' | |
'.hiddenfile' | 'hiddenfile' | |
'filename.with.many.dots.ext' | 'ext' | |
String 的split |
'' | '' |
'filename' | 'filename' | |
'filename.txt' | 'txt' | |
'.hiddenfile' | 'hiddenfile' | |
'filename.with.many.dots.ext' | 'ext' | |
String 的slice 和lastIndexOf |
'' | '' |
'filename' | '' | |
'filename.txt' | 'txt' | |
'.hiddenfile' | '' | |
'filename.with.many.dots.ext' | 'ext' |
原文地址:How to get the file extension more efficientlyprototype