最近,我在javascript中创建了一个函数,它接受文件名和最大字符限制,结果需要遵循以下规则:
现在我已经解决了这个问题,但是它让我思考在javascript中使用正则表达式或其他技术是否有一种更优雅或更简单的方法来完成这个任务。这也给了我一个尝试jsFiddle的机会。因此,考虑到这一点,我的职能是:
function ReduceFileName(name, max){
if(name.length > max){
var end = name.substring(name.lastIndexOf('.'));
var begin = name.substring(0, name.lastIndexOf('.'));
max = max - end.length - 3;
begin = begin.substr(0,max/2) + '...' + begin.substr(begin.length-(max/2) , max/2 + 1);
return begin + end;
}
return name;
}这是在js试验上
发布于 2010-03-18 16:03:53
因为我在这个问题上没有太多的活动,所以我假设没有更好的方法来做这件事,所以我将把我的方法作为答案,直到其他人想出其他的答案。
function ReduceFileName(name, max){
if(name.length > max){
var end = name.substring(name.lastIndexOf('.'));
var begin = name.substring(0, name.lastIndexOf('.'));
max = max - end.length - 3;
begin = begin.substr(0,max/2) + '...' + begin.substr(begin.length-(max/2) , max/2 + 1);
return begin + end;
}
return name;
}发布于 2010-03-04 00:51:50
我不确定正则表达式是否一定更优雅,但到目前为止,我提出了以下通过测试的方法:
function ReduceFileName(name, max){
if(name.length > max) {
var ell ="\u2026"; // defines replacement characters
var ext = (/\.[^\.]*$/.exec(name) || [""])[0]; // gets extension (with dot) or "" if no dot
var m = (max-ell.length-ext.length)/2; // splits the remaining # of characters
var a = Math.ceil(m);
var z = Math.floor(m);
var regex = new RegExp("^(.{"+a+"}).*(.{"+z+"})"+ext, "");
var ret = regex.exec(name);
return ret[1]+ell+ret[2]+ext;
}
return name;
}https://stackoverflow.com/questions/2375844
复制相似问题